@charset "utf-8";
@import url(https://use.typekit.net/onn5raf.css);

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  -webkit-text-size-adjust: 100%;
  line-height: 1.15
}

body {
  margin: 0
}

main {
  display: block
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible
}

pre {
  font-family: monospace, monospace;
  font-size: 1em
}

a {
  background-color: transparent
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

img {
  border-style: none
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

fieldset {
  padding: .35em .75em .625em
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

details {
  display: block
}

summary {
  display: list-item
}

[hidden],
template {
  display: none
}

[data-simplebar] {
  align-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: flex-start;
  position: relative
}

.simplebar-wrapper {
  height: inherit;
  max-height: inherit;
  max-width: inherit;
  overflow: hidden;
  width: inherit
}

.simplebar-mask {
  direction: inherit;
  height: auto !important;
  overflow: hidden;
  width: auto !important;
  z-index: 0
}

.simplebar-mask,
.simplebar-offset {
  bottom: 0;
  left: 0;
  margin: 0;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0
}

.simplebar-offset {
  -webkit-overflow-scrolling: touch;
  box-sizing: inherit !important;
  direction: inherit !important;
  resize: none !important
}

.simplebar-content-wrapper {
  -ms-overflow-style: none;
  box-sizing: border-box !important;
  direction: inherit;
  display: block;
  height: 100%;
  max-height: 100%;
  max-width: 100%;
  overflow: auto;
  position: relative;
  scrollbar-width: none;
  width: auto
}

.simplebar-content-wrapper::-webkit-scrollbar,
.simplebar-hide-scrollbar::-webkit-scrollbar {
  display: none;
  height: 0;
  width: 0
}

.simplebar-content:after,
.simplebar-content:before {
  content: " ";
  display: table
}

.simplebar-placeholder {
  max-height: 100%;
  max-width: 100%;
  pointer-events: none;
  width: 100%
}

.simplebar-height-auto-observer-wrapper {
  box-sizing: inherit !important;
  flex-basis: 0;
  flex-grow: inherit;
  flex-shrink: 0;
  float: left;
  height: 100%;
  margin: 0;
  max-height: 1px;
  max-width: 1px;
  overflow: hidden;
  padding: 0;
  pointer-events: none;
  position: relative;
  width: 100%;
  z-index: -1
}

.simplebar-height-auto-observer {
  box-sizing: inherit;
  display: block;
  height: 1000%;
  left: 0;
  min-height: 1px;
  min-width: 1px;
  opacity: 0;
  top: 0;
  width: 1000%;
  z-index: -1
}

.simplebar-height-auto-observer,
.simplebar-track {
  overflow: hidden;
  pointer-events: none;
  position: absolute
}

.simplebar-track {
  bottom: 0;
  right: 0;
  z-index: 1
}

[data-simplebar].simplebar-dragging,
[data-simplebar].simplebar-dragging .simplebar-content {
  -webkit-touch-callout: none;
  pointer-events: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none
}

[data-simplebar].simplebar-dragging .simplebar-track {
  pointer-events: all
}

.simplebar-scrollbar {
  left: 0;
  min-height: 10px;
  position: absolute;
  right: 0
}

.simplebar-scrollbar:before {
  background: #000;
  border-radius: 7px;
  content: "";
  opacity: 0;
  position: absolute;
  transition: opacity .2s linear .5s
}

.simplebar-scrollbar.simplebar-visible:before {
  opacity: .5;
  transition-delay: 0s;
  transition-duration: 0s
}

.simplebar-track.simplebar-vertical {
  top: 0;
  width: 11px
}

.simplebar-scrollbar:before {
  bottom: 2px;
  left: 2px;
  right: 2px;
  top: 2px
}

.simplebar-track.simplebar-horizontal {
  height: 11px;
  left: 0
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
  bottom: 0;
  left: 0;
  min-height: 0;
  min-width: 10px;
  right: auto;
  top: 0;
  width: auto
}

[data-simplebar-direction=rtl] .simplebar-track.simplebar-vertical {
  left: 0;
  right: auto
}

.simplebar-dummy-scrollbar-size {
  -ms-overflow-style: scrollbar !important;
  direction: rtl;
  height: 500px;
  opacity: 0;
  overflow-x: scroll;
  overflow-y: hidden;
  position: fixed;
  visibility: hidden;
  width: 500px
}

.simplebar-dummy-scrollbar-size>div {
  height: 200%;
  margin: 10px 0;
  width: 200%
}

.simplebar-hide-scrollbar {
  -ms-overflow-style: none;
  left: 0;
  overflow-y: scroll;
  position: fixed;
  scrollbar-width: none;
  visibility: hidden
}

/*!
 * Font Awesome Pro 6.7.1 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license (Commercial License)
 * Copyright 2024 Fonticons, Inc.
 */
.fa {
  font-family: var(--fa-style-family, "Font Awesome 6 Pro");
  font-weight: var(--fa-style, 900)
}

.fa,
.fa-brands,
.fa-classic,
.fa-duotone,
.fa-light,
.fa-regular,
.fa-sharp,
.fa-sharp-duotone,
.fa-solid,
.fa-thin,
.fab,
.fad,
.fadl,
.fadr,
.fadt,
.fal,
.far,
.fas,
.fasdl,
.fasdr,
.fasds,
.fasdt,
.fasl,
.fasr,
.fass,
.fast,
.fat {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  display: var(--fa-display, inline-block);
  font-style: normal;
  font-variant: normal;
  line-height: 1;
  text-rendering: auto
}

.fa-brands:before,
.fa-classic:before,
.fa-duotone:before,
.fa-light:before,
.fa-regular:before,
.fa-sharp-duotone:before,
.fa-sharp:before,
.fa-solid:before,
.fa-thin:before,
.fa:before,
.fab:before,
.fad:before,
.fadl:before,
.fadr:before,
.fadt:before,
.fal:before,
.far:before,
.fas:before,
.fasdl:before,
.fasdr:before,
.fasds:before,
.fasdt:before,
.fasl:before,
.fasr:before,
.fass:before,
.fast:before,
.fat:before {
  content: var(--fa)
}

.fa-duotone.fa-light:after,
.fa-duotone.fa-regular:after,
.fa-duotone.fa-solid:after,
.fa-duotone.fa-thin:after,
.fa-duotone:after,
.fa-sharp-duotone.fa-light:after,
.fa-sharp-duotone.fa-regular:after,
.fa-sharp-duotone.fa-solid:after,
.fa-sharp-duotone.fa-thin:after,
.fa-sharp-duotone:after,
.fad:after,
.fadl:after,
.fadr:after,
.fadt:after,
.fasdl:after,
.fasdr:after,
.fasds:after,
.fasdt:after {
  content: var(--fa--fa)
}

.fa-classic.fa-duotone {
  font-family: Font Awesome\ 6 Duotone
}

.fa-duotone,
.fa-sharp,
.fa-sharp-duotone,
.fad,
.fasds,
.fass {
  font-weight: 900
}

.fa-classic,
.fa-light,
.fa-regular,
.fa-solid,
.fa-thin,
.fal,
.far,
.fas,
.fat {
  font-family: Font Awesome\ 6 Pro
}

.fa-duotone,
.fad,
.fadl,
.fadr,
.fadt {
  font-family: Font Awesome\ 6 Duotone
}

.fa-brands,
.fab {
  font-family: Font Awesome\ 6 Brands
}

.fa-sharp,
.fasl,
.fasr,
.fass,
.fast {
  font-family: Font Awesome\ 6 Sharp
}

.fa-sharp-duotone,
.fasdl,
.fasdr,
.fasds,
.fasdt {
  font-family: Font Awesome\ 6 Sharp Duotone
}

.fa-1x {
  font-size: 1em
}

.fa-2x {
  font-size: 2em
}

.fa-3x {
  font-size: 3em
}

.fa-4x {
  font-size: 4em
}

.fa-5x {
  font-size: 5em
}

.fa-6x {
  font-size: 6em
}

.fa-7x {
  font-size: 7em
}

.fa-8x {
  font-size: 8em
}

.fa-9x {
  font-size: 9em
}

.fa-10x {
  font-size: 10em
}

.fa-2xs {
  font-size: .625em;
  line-height: .1em;
  vertical-align: .225em
}

.fa-xs {
  font-size: .75em;
  line-height: .0833333337em;
  vertical-align: .125em
}

.fa-sm {
  font-size: .875em;
  line-height: .0714285718em;
  vertical-align: .0535714295em
}

.fa-lg {
  font-size: 1.25em;
  line-height: .05em;
  vertical-align: -.075em
}

.fa-xl {
  font-size: 1.5em;
  line-height: .0416666682em;
  vertical-align: -.125em
}

.fa-2xl {
  font-size: 2em;
  line-height: .03125em;
  vertical-align: -.1875em
}

.fa-fw {
  text-align: center;
  width: 1.25em
}

.fa-ul {
  list-style-type: none;
  margin-left: var(--fa-li-margin, 2.5em);
  padding-left: 0
}

.fa-ul>li {
  position: relative
}

.fa-li {
  left: calc(var(--fa-li-width, 2em)*-1);
  line-height: inherit;
  position: absolute;
  text-align: center;
  width: var(--fa-li-width, 2em)
}

.fa-border {
  border-color: var(--fa-border-color, #eee);
  border-radius: var(--fa-border-radius, .1em);
  border-style: var(--fa-border-style, solid);
  border-width: var(--fa-border-width, .08em);
  padding: var(--fa-border-padding, .2em .25em .15em)
}

.fa-pull-left {
  float: left;
  margin-right: var(--fa-pull-margin, .3em)
}

.fa-pull-right {
  float: right;
  margin-left: var(--fa-pull-margin, .3em)
}

.fa-beat {
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-beat;
  animation-timing-function: var(--fa-animation-timing, ease-in-out)
}

.fa-bounce {
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-bounce;
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(.28, .84, .42, 1))
}

.fa-fade {
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-fade;
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1))
}

.fa-beat-fade,
.fa-fade {
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s)
}

.fa-beat-fade {
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-beat-fade;
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(.4, 0, .6, 1))
}

.fa-flip {
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-flip;
  animation-timing-function: var(--fa-animation-timing, ease-in-out)
}

.fa-shake {
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-shake;
  animation-timing-function: var(--fa-animation-timing, linear)
}

.fa-shake,
.fa-spin {
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal)
}

.fa-spin {
  animation-duration: var(--fa-animation-duration, 2s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-spin;
  animation-timing-function: var(--fa-animation-timing, linear)
}

.fa-spin-reverse {
  --fa-animation-direction: reverse
}

.fa-pulse,
.fa-spin-pulse {
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-name: fa-spin;
  animation-timing-function: var(--fa-animation-timing, steps(8))
}

@media(prefers-reduced-motion:reduce) {

  .fa-beat,
  .fa-beat-fade,
  .fa-bounce,
  .fa-fade,
  .fa-flip,
  .fa-pulse,
  .fa-shake,
  .fa-spin,
  .fa-spin-pulse {
    animation-delay: -1ms;
    animation-duration: 1ms;
    animation-iteration-count: 1;
    transition-delay: 0s;
    transition-duration: 0s
  }
}

@keyframes fa-beat {

  0%,
  90% {
    transform: scale(1)
  }

  45% {
    transform: scale(var(--fa-beat-scale, 1.25))
  }
}

@keyframes fa-bounce {
  0% {
    transform: scale(1) translateY(0)
  }

  10% {
    transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, .9)) translateY(0)
  }

  30% {
    transform: scale(var(--fa-bounce-jump-scale-x, .9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -.5em))
  }

  50% {
    transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, .95)) translateY(0)
  }

  57% {
    transform: scale(1) translateY(var(--fa-bounce-rebound, -.125em))
  }

  64% {
    transform: scale(1) translateY(0)
  }

  to {
    transform: scale(1) translateY(0)
  }
}

@keyframes fa-fade {
  50% {
    opacity: var(--fa-fade-opacity, .4)
  }
}

@keyframes fa-beat-fade {

  0%,
  to {
    opacity: var(--fa-beat-fade-opacity, .4);
    transform: scale(1)
  }

  50% {
    opacity: 1;
    transform: scale(var(--fa-beat-fade-scale, 1.125))
  }
}

@keyframes fa-flip {
  50% {
    transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg))
  }
}

@keyframes fa-shake {
  0% {
    transform: rotate(-15deg)
  }

  4% {
    transform: rotate(15deg)
  }

  24%,
  8% {
    transform: rotate(-18deg)
  }

  12%,
  28% {
    transform: rotate(18deg)
  }

  16% {
    transform: rotate(-22deg)
  }

  20% {
    transform: rotate(22deg)
  }

  32% {
    transform: rotate(-12deg)
  }

  36% {
    transform: rotate(12deg)
  }

  40%,
  to {
    transform: rotate(0deg)
  }
}

@keyframes fa-spin {
  0% {
    transform: rotate(0deg)
  }

  to {
    transform: rotate(1turn)
  }
}

.fa-rotate-90 {
  transform: rotate(90deg)
}

.fa-rotate-180 {
  transform: rotate(180deg)
}

.fa-rotate-270 {
  transform: rotate(270deg)
}

.fa-flip-horizontal {
  transform: scaleX(-1)
}

.fa-flip-vertical {
  transform: scaleY(-1)
}

.fa-flip-both,
.fa-flip-horizontal.fa-flip-vertical {
  transform: scale(-1)
}

.fa-rotate-by {
  transform: rotate(var(--fa-rotate-angle, 0))
}

.fa-stack {
  display: inline-block;
  height: 2em;
  line-height: 2em;
  position: relative;
  vertical-align: middle;
  width: 2.5em
}

.fa-stack-1x,
.fa-stack-2x {
  left: 0;
  position: absolute;
  text-align: center;
  width: 100%;
  z-index: var(--fa-stack-z-index, auto)
}

.fa-stack-1x {
  line-height: inherit
}

.fa-stack-2x {
  font-size: 2em
}

.fa-inverse {
  color: var(--fa-inverse, #fff)
}

.fa-arrow-left {
  --fa: "";
  --fa--fa: ""
}

.fa-arrow-right {
  --fa: "";
  --fa--fa: ""
}

.fa-archive,
.fa-box-archive {
  --fa: "";
  --fa--fa: ""
}

.fa-calendar-lines,
.fa-calendar-note {
  --fa: "";
  --fa--fa: ""
}

.fa-check {
  --fa: "";
  --fa--fa: ""
}

.fa-chevron-down {
  --fa: "";
  --fa--fa: ""
}

.fa-chevron-left {
  --fa: "";
  --fa--fa: ""
}

.fa-chevron-right {
  --fa: "";
  --fa--fa: ""
}

.fa-chevron-up {
  --fa: "";
  --fa--fa: ""
}

.fa-circle-play,
.fa-play-circle {
  --fa: "";
  --fa--fa: ""
}

.fa-circle-user,
.fa-user-circle {
  --fa: "";
  --fa--fa: ""
}

.fa-clock,
.fa-clock-four {
  --fa: "";
  --fa--fa: ""
}

.fa-download {
  --fa: "";
  --fa--fa: ""
}

.fa-envelope {
  --fa: "";
  --fa--fa: ""
}

.fa-filter {
  --fa: "";
  --fa--fa: ""
}

.fa-home,
.fa-home-alt,
.fa-home-lg-alt,
.fa-house {
  --fa: "";
  --fa--fa: ""
}

.fa-chain,
.fa-link {
  --fa: "";
  --fa--fa: ""
}

.fa-location-dot,
.fa-map-marker-alt {
  --fa: "";
  --fa--fa: ""
}

.fa-magnifying-glass,
.fa-search {
  --fa: "";
  --fa--fa: ""
}

.fa-ticket {
  --fa: "";
  --fa--fa: ""
}

.fa-television,
.fa-tv,
.fa-tv-alt {
  --fa: "";
  --fa--fa: ""
}

.fa-user {
  --fa: "";
  --fa--fa: ""
}

.fa-close,
.fa-multiply,
.fa-remove,
.fa-times,
.fa-xmark {
  --fa: "";
  --fa--fa: ""
}

.fa-sr-only,
.fa-sr-only-focusable:not(:focus),
.sr-only,
.sr-only-focusable:not(:focus) {
  clip: rect(0, 0, 0, 0);
  border-width: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px
}

/*!
 * Font Awesome Pro 6.7.1 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license (Commercial License)
 * Copyright 2024 Fonticons, Inc.
 */
:host,
:root {
  --fa-font-solid: normal 900 1em/1 "Font Awesome 6 Pro"
}

@font-face {
  font-display: block;
  font-family: Font Awesome\ 6 Pro;
  font-style: normal;
  font-weight: 900;
  src: url(../webfonts/fa-solid-900.woff2) format("woff2"), url(../webfonts/fa-solid-900.ttf) format("truetype")
}

.fa-solid,
.fas {
  font-weight: 900
}

/*!
 * Font Awesome Pro 6.7.1 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license (Commercial License)
 * Copyright 2024 Fonticons, Inc.
 */
:host,
:root {
  --fa-style-family-classic: "Font Awesome 6 Pro";
  --fa-font-regular: normal 400 1em/1 "Font Awesome 6 Pro"
}

@font-face {
  font-display: block;
  font-family: Font Awesome\ 6 Pro;
  font-style: normal;
  font-weight: 400;
  src: url(../webfonts/fa-regular-400.woff2) format("woff2"), url(../webfonts/fa-regular-400.ttf) format("truetype")
}

.fa-regular,
.far {
  font-weight: 400
}

/*!
 * Font Awesome Pro 6.7.1 by @fontawesome - https://fontawesome.com
 * License - https://fontawesome.com/license (Commercial License)
 * Copyright 2024 Fonticons, Inc.
 */
:host,
:root {
  --fa-style-family-brands: "Font Awesome 6 Brands";
  --fa-font-brands: normal 400 1em/1 "Font Awesome 6 Brands"
}

@font-face {
  font-display: block;
  font-family: Font Awesome\ 6 Brands;
  font-style: normal;
  font-weight: 400;
  src: url(../webfonts/fa-brands-400.woff2) format("woff2"), url(../webfonts/fa-brands-400.ttf) format("truetype")
}

.fa-brands,
.fab {
  font-weight: 400
}

.fa-bluesky {
  --fa: ""
}

.fa-facebook-f {
  --fa: ""
}

.fa-instagram {
  --fa: ""
}

.fa-linkedin-in {
  --fa: ""
}

.fa-threads {
  --fa: ""
}

.fa-twitter {
  --fa: ""
}

.fa-x-twitter {
  --fa: ""
}

.fa-youtube {
  --fa: ""
}

@keyframes blink {
  0% {
    opacity: .6
  }

  10% {
    opacity: 1
  }

  to {
    opacity: .6
  }
}

@keyframes chat-box-button-bounce {
  0% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(-20px)
  }

  to {
    transform: translateY(0)
  }
}

@keyframes spinner-rotate {
  0% {
    transform: rotate(0)
  }

  to {
    transform: rotate(1turn)
  }
}

@keyframes diffusion {
  0% {
    opacity: 1;
    transform: scale(.2)
  }

  75% {
    transform: scale(1.25)
  }

  to {
    opacity: 0;
    transform: scale(1.25)
  }
}

.vjs-poster img {
  height: 100%;
  object-fit: cover;
  width: 100%
}

@media(max-width:820px) {
  .u-desktop {
    display: none !important
  }
}

@media(min-width:820px) {
  .u-tablet {
    display: none !important
  }
}

@media(min-width:480px) {
  .u-mobile {
    display: none !important
  }
}

@media(max-width:1079px) {
  .u-laptop {
    display: none !important
  }
}

@media only screen and (max-width:1172px) {
  .u-header-desktop {
    display: none
  }
}

@media only screen and (min-width:1080px) {
  .u-header-mobile {
    display: none !important
  }
}

.u-left {
  float: left
}

.u-right {
  float: right
}

.u-inner {
  margin-left: auto;
  margin-right: auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2);
  padding: 0 var(--content-space);
  width: 100%
}

@media(max-width:820px) {
  .u-inner {
    padding: 0 var(--content-space-m)
  }
}

@media(max-width:480px) {
  .u-inner {
    padding: 0 var(--content-space-s)
  }
}

.u-note:before {
  content: "※";
  display: inline-block
}

.u-first-letter {
  font-size: 1.7em;
  font-weight: 700
}

.u-highlight {
  background-color: var(--colour-primary-light);
  padding: 2px
}

.u-image-cover {
  height: 100%;
  object-fit: cover;
  width: 100%
}

.u-center-vertical {
  left: 0;
  top: 50%;
  transform: translateY(-50);
  width: 100%
}

.u-card-link {
  cursor: pointer;
  height: 100%;
  left: 0;
  position: absolute !important;
  top: 0;
  width: 100%;
  z-index: 99
}

.u-list-link {
  background: none;
  border: none;
  border-bottom: 1px solid var(--colour-border-light);
  color: inherit;
  cursor: pointer;
  display: inline-block;
  padding: .333em 0;
  text-decoration: none;
  width: 100%
}

.u-list-link:hover {
  opacity: .8;
  text-decoration: none
}

.is-dark .u-list-link {
  border-bottom-color: #fff
}

.is-light .u-list-link {
  border-bottom-color: var(--colour-border-light)
}

.u-list-link:before {
  align-items: center;
  color: var(--colour-primary);
  content: "";
  font-family: var(--font-fontawesome);
  font-size: .666em;
  font-weight: 600;
  justify-content: center;
  margin-right: 8px;
  vertical-align: 1px
}

.u-text-center {
  text-align: center
}

.u-text-right {
  text-align: right
}

.u-text-left {
  text-align: left
}

.u-text-underline {
  text-decoration: underline
}

.u-text-italic {
  font-style: italic
}

.u-text-note {
  font-size: 12px
}

.u-text-large {
  font-size: var(--font-size-l);
  line-height: 1.2;
  margin-bottom: 1em
}

.u-text-larger {
  font-size: var(--font-size-xl);
  line-height: 1.2
}

@media(max-width:819px) {
  .u-text-larger {
    font-size: var(--font-size-l)
  }
}

.u-text-link {
  text-decoration: underline
}

.u-text-link:hover {
  text-decoration: none
}

.u-button-link {
  background: none;
  border: none;
  color: inherit;
  outline: none
}

.u-card-text-link {
  color: inherit;
  text-decoration: none
}

.u-card-text-link:hover {
  text-decoration: underline
}

.u-text-not-ready {
  pointer-events: none;
  text-decoration-line: line-through
}

.u-text-hide {
  color: transparent;
  display: block;
  font-size: 0;
  height: 0;
  text-indent: -9999px
}

.u-text-with-icon {
  align-items: center;
  display: inline-flex;
  padding: 0 6px;
  vertical-align: middle
}

@media(max-width:820px) {
  .u-text-with-icon {
    padding: 0 4px
  }
}

.u-text-with-icon>.icon,
.u-text-with-icon>i {
  font-size: 16px;
  margin-right: 8px
}

@media(max-width:820px) {

  .u-text-with-icon>.icon,
  .u-text-with-icon>i {
    font-size: 20px
  }
}

.u-weak {
  opacity: .6
}

.u-hidden {
  height: 0;
  margin: 0;
  opacity: 0;
  padding: 0;
  pointer-events: none;
  text-indent: -9999px;
  visibility: hidden;
  width: 0
}

.u-display-none {
  display: none
}

.u-flex-end {
  align-items: flex-end
}

.u-flex-center {
  align-items: center
}

.u-flex-wrap {
  flex-wrap: wrap
}

.u-space-between {
  justify-content: space-between
}

.u-space-around {
  justify-content: space-around
}

@media(max-width:820px) {
  .u-flex-column-mobile {
    flex-direction: column
  }
}

.u-flex {
  display: flex
}

@media(max-width:820px) {
  .u-flex-mobile {
    display: flex
  }
}

.u-flex-2>* {
  width: 50%
}

.u-flex-3>* {
  width: 33.333%
}

.u-flex-4>* {
  width: 25%
}

.u-flex-5>* {
  width: 20%
}

.u-flex-justify-center {
  justify-content: center
}

.u-flex-justify-between {
  justify-content: space-between
}

.u-flex-align-center {
  align-items: center
}

.u-grid {
  grid-column-gap: var(--grid-gutter-space);
  align-items: flex-start;
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(12, 1fr);
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2);
  padding-left: var(--content-space);
  padding-right: var(--content-space);
  width: 100%
}

@media(max-width:479px) {
  .u-grid {
    grid-template-columns: repeat(4, 1fr)
  }
}

.u-read-more-link {
  font-weight: var(--font-weight-semibold)
}

.u-read-more-link:disabled {
  opacity: .6
}

.u-read-more-link:hover:not(.u-read-more-link:disabled) {
  color: var(--colour-primary)
}

.u-read-more-link:hover:not(:disabled) .u-read-more-link__icon:after {
  transform: translateX(10px)
}

.u-font-weight-normal {
  font-weight: 400 !important
}

.u-colour-primary {
  color: var(--colour-primary)
}

.u-colour-tertiary {
  color: var(--colour-tertiary)
}

.u-colour-font {
  color: var(--colour-font)
}

.u-colour-inherit {
  color: inherit
}

.u-colour-green {
  color: var(--colour-green)
}

.u-bg-colour-primary {
  background-color: var(--colour-primary)
}

.u-bg-colour-secondary {
  background-color: var(--colour-secondary)
}

.u-full-width {
  width: 100%
}

.u-title {
  margin-top: 0
}

.u-order-1 {
  order: 1
}

.u-order-2 {
  order: 2
}

.u-order-3 {
  order: 3
}

.u-order-4 {
  order: 4
}

@media(max-width:820px) {
  .u-order-1-mobile {
    margin-top: 0 !important;
    order: 1
  }

  .u-order-2-mobile {
    order: 2
  }

  .u-order-3-mobile {
    order: 3
  }

  .u-order-4-mobile {
    order: 4
  }
}

.u-pb-0 {
  padding-bottom: 0 !important
}

.u-mb-0 {
  margin-bottom: 0 !important
}

.u-pt-0 {
  padding-top: 0 !important
}

.u-mt-0 {
  margin-top: 0 !important
}

.u-button-plain {
  background: none;
  border: none;
  padding: 0
}

.u-image-focal-point {
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  object-position: var(--x) var(--y);
  width: 100%
}

.u-image-focal-point-bg {
  background-position: var(--x) var(--y) !important;
  background-repeat: no-repeat !important;
  background-size: cover !important
}

.u-h1 {
  font-size: var(--font-size-h1)
}

@media(max-width:820px) {
  .u-h1 {
    font-size: var(--font-size-h1-mobile)
  }
}

.u-h2 {
  font-size: var(--font-size-h2)
}

@media(max-width:820px) {
  .u-h2 {
    font-size: var(--font-size-2-mobile)
  }
}

.u-h3 {
  font-size: var(--font-size-h3)
}

@media(max-width:820px) {
  .u-h3 {
    font-size: var(--font-size-h3-mobile)
  }
}

.u-h4 {
  font-size: var(--font-size-h4)
}

@media(max-width:820px) {
  .u-h4 {
    font-size: var(--font-size-h4-mobile)
  }
}

.u-h5 {
  font-size: var(--font-size-h5)
}

@media(max-width:820px) {
  .u-h5 {
    font-size: var(--font-size-h5-mobile)
  }
}

:root {
  --path-image: "/assets/images";
  --content-width-min: 920px;
  --content-width-max: 1600px;
  --content-width-inner: 1316px;
  --content-space: 24px;
  --content-space-xl: 60px;
  --content-space-l: 40px;
  --content-space-m: 32px;
  --content-space-s: 16px;
  --content-space-xs: 12px;
  --content-space-section: 48px;
  --content-space-section-mobile: 40px;
  --content-space-head: 24px;
  --content-space-mobile: 20px;
  --layout-header-height: 144px;
  --grid-width: 96px;
  --grid-margin: 0;
  --grid-gutter-space: 16px;
  --grid-gutter-space-mobile: 12px;
  --fixed-top: 0;
  --font-primary: "proxima-nova", "Helvetica", sans-serif;
  --font-fontawesome: "Font Awesome 6 Pro", sans-serif;
  --font-size-base: 16px;
  --font-size-h1: 48px;
  --font-size-h1-mobile: 40px;
  --font-size-h2: 40px;
  --font-size-h2-mobile: 28px;
  --font-size-h3: 32px;
  --font-size-h3-mobile: 24px;
  --font-size-h4: 24px;
  --font-size-h4-mobile: 18px;
  --font-size-h5: 18px;
  --font-size-h5-mobile: 16px;
  --font-size-h6: 16px;
  --font-size-h6-mobile: 14px;
  --font-size-xxl: 32px;
  --font-size-xl: 28px;
  --font-size-l: 24px;
  --font-size-m: 18px;
  --font-size-s: 12px;
  --font-size-label: 14px;
  --font-weight-bold: 700;
  --font-weight-semibold: 600;
  --font-weight-regular: 400;
  --font-weight-fontawesome: 900;
  --font-style-italic: italic;
  --colour-font: #333132;
  --colour-font-light: rgba(0, 0, 0, .7);
  --colour-font-lighter: rgba(0, 0, 0, .5);
  --colour-font-lightest: rgba(0, 0, 0, .3);
  --colour-primary: #d31245;
  --colour-primary-light: rgba(255, 150, 152, .1);
  --colour-secondary: #ede7dd;
  --colour-tertiary: #6f263d;
  --colour-white: #fff;
  --colour-bg: #f6f6f6;
  --colour-grey: #cacaca;
  --colour-light-grey: #f5f5f5;
  --colour-medium-grey: #f2f2f2;
  --colour-border: #978c87;
  --colour-border-light: hsla(22, 13%, 47%, .2);
  --colour-error: #d31245;
  --colour-error-light: #865c63;
  --colour-disabled: rgba(0, 0, 0, .3);
  --colour-orange: #ed8b00;
  --colour-purple: #a51890;
  --colour-green: #64a70b;
  --colour-warm-grey: #978c87;
  --colour-plum: #6f263d;
  --colour-warm-grey-accessible: #867368;
  --colour-shadow: transparent linear-gradient(180deg, #0000, #000000c7) 0% 0% no-repeat padding-box;
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --shadow-card: 0 4px 2px 0 rgba(0, 0, 0, .05);
  --shadow-card-hover: 0 4px 10px 0 rgba(0, 0, 0, .05);
  --shadow-m: 0 20px 20px #9353530d;
  --shadow-l: 0 10px 20px rgba(50, 50, 50, .14), 0 6px 6px rgb(50 50 50/8%);
  --shadow-text-dark: 0 0 12px rgba(0, 0, 0, .6);
  --shadow-text-light: 0 0 12px hsla(0, 0%, 100%, .6)
}

* {
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
  text-rendering: optimizeLegibility
}

html {
  font-size: var(--font-size-base)
}

body,
html {
  background-color: var(--colour-white)
}

body {
  color: var(--colour-font);
  font-family: var(--font-primary);
  font-size: 100%;
  font-weight: var(--font-weight-regular);
  letter-spacing: .1px;
  line-height: 1.5
}

body.is-navigation-open {
  overflow: hidden
}

html,
input,
select,
textarea {
  color: var(--colour-font)
}

hr {
  border: 0;
  border-top: 1px solid var(--colour-border);
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0
}

audio,
canvas,
img,
video {
  vertical-align: middle
}

fieldset {
  border: 0;
  margin: 0;
  padding: 0
}

textarea {
  resize: vertical
}

sub {
  font-size: .6em;
  opacity: .8;
  vertical-align: baseline
}

ol,
ul {
  padding-left: 18px
}

li {
  margin-bottom: 1rem
}

p,
q {
  margin-bottom: 1em;
  margin-top: 0
}

q {
  display: block;
  font-style: italic
}

a,
q {
  font-weight: var(--font-weight-semibold)
}

a {
  color: var(--colour-primary);
  text-decoration: none
}

a:hover {
  text-decoration: underline
}

button {
  color: inherit;
  font-size: 1em
}

button:not(button:disabled) {
  cursor: pointer
}

img {
  display: inline;
  max-width: 100%
}

svg {
  width: 100%
}

.blockquote,
blockquote {
  margin: 20px 0;
  padding: 0 20px;
  position: relative
}

.blockquote:before,
blockquote:before {
  content: "“";
  font-size: 48px;
  left: 0;
  position: absolute;
  top: 0;
  transform: translateY(-32px)
}

.blockquote:after,
blockquote:after {
  bottom: 0;
  content: "“";
  font-size: 48px;
  line-height: .1em;
  margin-left: .25em;
  position: absolute;
  transform: scaleX(-1);
  vertical-align: -.4em
}

.blockquote__avatar,
blockquote__avatar {
  margin-top: 15px
}

.blockquote p,
blockquote p {
  display: inline
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-secondary);
  font-weight: var(--font-weight-semibold);
  line-height: 1.3;
  margin: 1em 0 .46em;
  position: relative
}

h1 {
  font-size: var(--font-size-h1);
  line-height: 1.1;
  margin-top: 0
}

@media(max-width:820px) {
  h1 {
    font-size: var(--font-size-h1-mobile)
  }
}

h2 {
  font-size: var(--font-size-h2);
  line-height: 1.2;
  margin: 1em 0 .46em
}

@media(max-width:820px) {
  h2 {
    font-size: var(--font-size-h2-mobile)
  }
}

h3 {
  font-size: var(--font-size-h3);
  line-height: 1.2
}

@media(max-width:820px) {
  h3 {
    font-size: var(--font-size-h3-mobile)
  }
}

h4 {
  font-size: var(--font-size-h4);
  line-height: 1.3
}

@media(max-width:820px) {
  h4 {
    font-size: var(--font-size-h4-mobile)
  }
}

h5 {
  font-size: var(--font-size-h5);
  line-height: 1.4
}

@media(max-width:820px) {
  h5 {
    font-size: var(--font-size-h5-mobile)
  }
}

h6 {
  font-size: var(--font-size-h6);
  line-height: 1.5
}

em {
  font-family: var(--font-primary-italic)
}

.visuallyhidden {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px
}

.util-control {
  background-color: #fff;
  bottom: 0;
  color: #000;
  padding: 4px 15px;
  position: fixed;
  right: 0;
  text-align: center;
  z-index: 999
}

.util-control input,
.util-control label {
  cursor: pointer !important
}

.util-control__title {
  margin-right: 12px
}

.util-grids {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  display: none;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(12, 1fr);
  height: 100%;
  justify-content: space-between;
  left: 0;
  margin: auto;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 999
}

@media(max-width:479px) {
  .util-grids {
    grid-template-columns: repeat(4, 1fr)
  }
}

.util-grids.is-active {
  display: flex
}

.util-grid {
  background-color: #fd6697;
  height: 100%;
  min-height: 40px;
  opacity: .2
}

::selection {
  background: var(--colour-secondary);
  color: var(--colour-font);
  text-shadow: none
}

::-webkit-selection {
  background: var(--colour-secondary);
  color: var(--colour-font);
  text-shadow: none
}

::placeholder {
  color: rgba(0, 0, 0, .6)
}

.button {
  align-items: center;
  background-color: var(--colour-white);
  border: none;
  cursor: pointer;
  display: inline-flex;
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 600;
  justify-content: center;
  padding: 15px 24px;
  position: relative;
  transition: opacity .1s ease, transform .4s ease
}

.button:hover {
  color: var(--colour-font);
  text-decoration: none
}

.button--primary:not([disabled]) {
  background-color: var(--colour-primary);
  color: var(--colour-white)
}

.button--primary:not([disabled]):hover {
  color: var(--colour-white)
}

.button--secondary:not([disabled]) {
  background-color: var(--colour-secondary);
  color: var(--colour-font)
}

.button--tertiary:not([disabled]) {
  background-color: var(--colour-tertiary)
}

.button--black {
  background-color: var(--colour-font)
}

.button--black,
.button--black:hover {
  color: var(--colour-white)
}

.button--white {
  color: var(--colour-font)
}

.button--small {
  height: 36px
}

.button[data-icon-position=left]:before {
  justify-content: flex-end
}

.button:not([disabled]):hover {
  opacity: .9;
  transform: translateY(-2px) scale(.98)
}

.button[disabled] {
  background-color: var(--colour-light-grey);
  color: var(--colour-grey);
  cursor: not-allowed
}

.button-container {
  align-items: center;
  display: flex
}

.button-container>:first-child {
  margin-right: var(--grid-gutter-space)
}

.button-container>:last-child {
  margin-right: 0
}

.button-container--vertical {
  align-items: flex-start;
  flex-direction: column
}

.button-container--vertical>:first-child {
  margin-bottom: 1rem;
  margin-right: 0
}

.link-button {
  align-items: center;
  color: var(--colour-primary);
  display: inline-flex;
  font-weight: var(--font-weight-semibold);
  position: relative
}

.link-button:after {
  background-image: url(../icons/arrow-right@2x.png);
  background-size: cover;
  content: "";
  display: inline-block;
  height: 14px;
  margin-left: 10px;
  transition: transform .5s ease;
  width: 27px
}

.link-button:hover {
  text-decoration: none
}

.link-button:hover:after {
  transform: translateX(6px)
}

.lead-button {
  align-items: center;
  background: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  flex-shrink: 0;
  outline: none;
  padding: 0 30px 0 0;
  position: relative;
  transition: color .4s;
  z-index: 1
}

.lead-button:disabled {
  cursor: auto;
  filter: grayscale(1);
  opacity: .8
}

.lead-button:after {
  background-color: var(--colour-primary);
  border-radius: 40px;
  content: "";
  height: 40px;
  left: 0;
  position: absolute;
  top: 0;
  transition: all .4s;
  width: 40px;
  z-index: -1
}

.lead-button:before {
  align-items: center;
  color: #fff;
  content: "";
  display: inline-flex;
  font-family: var(--font-fontawesome);
  font-weight: var(--font-weight-fontawesome);
  height: 40px;
  justify-content: center;
  margin-right: 8px;
  width: 40px
}

.lead-button.is-active,
.lead-button.is-warning,
.lead-button:hover:not(.lead-button:disabled) {
  color: #fff
}

.lead-button.is-active:after,
.lead-button.is-warning:after,
.lead-button:hover:not(.lead-button:disabled):after {
  background-color: var(--colour-primary-darker);
  transform: translateX(0);
  width: 100%
}

.lead-button.is-warning:not(.lead-button:disabled):after {
  background-color: var(--colour-error)
}

.lead-button.is-warning:not(.lead-button:disabled):hover:after {
  opacity: .8;
  transition: opacity .4
}

.menu-button {
  align-items: center;
  background: none;
  border: none;
  display: flex;
  height: 19px;
  justify-content: center;
  outline: none;
  padding: 0;
  position: relative;
  width: 40px
}

@media(max-width:820px) {
  .menu-button {
    padding: 0 4px;
    width: 42px
  }
}

.menu-button.is-active {
  width: 32px
}

.menu-button__inner {
  background-color: var(--colour-font);
  border-radius: 2px;
  display: block;
  height: 3px;
  position: relative;
  width: 24px
}

.menu-button__inner:before {
  transform: translateY(-7px);
  width: 24px
}

.menu-button__inner:after {
  transform: translateY(7px);
  width: 24px
}

.menu-button__inner:after,
.menu-button__inner:before {
  background-color: var(--colour-font);
  border-radius: 2px;
  content: "";
  height: 3px;
  position: absolute;
  right: 0;
  top: 0;
  transition: tranform .4s, width .4s
}

.is-light:not(.is-navigation-open):not(.is-fixed) .menu-button__inner:after,
.is-light:not(.is-navigation-open):not(.is-fixed) .menu-button__inner:before {
  background-color: #fff
}

.menu-button:hover .menu-button__inner:after,
.menu-button:hover .menu-button__inner:before {
  width: 27px
}

.menu-button.is-active .menu-button__inner {
  background-color: transparent
}

.menu-button.is-active .menu-button__inner:after,
.menu-button.is-active .menu-button__inner:before {
  width: 18px
}

.menu-button.is-active .menu-button__inner:before {
  transform: rotate(45deg)
}

.menu-button.is-active .menu-button__inner:after {
  transform: rotate(-45deg)
}

.is-light:not(.is-navigation-open):not(.is-fixed) .menu-button__inner,
.scroll-nav-button {
  background-color: #fff
}

.scroll-nav-button {
  border: none;
  border-radius: 50%;
  box-shadow: var(--shadow-l);
  font-size: 20px;
  height: 48px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  z-index: 3
}

@media(max-width:820px) {
  .scroll-nav-button {
    opacity: 1 !important;
    visibility: visible !important
  }
}

.scroll-nav-button--next {
  right: 1rem
}

.scroll-nav-button--prev {
  left: 1rem
}

.scroll-nav-button:disabled {
  background-color: hsla(0, 0%, 78%, .8)
}

.close-button {
  background-color: transparent;
  border: none;
  color: transparent;
  cursor: pointer;
  height: 24px;
  justify-self: center;
  margin-left: auto;
  outline: none;
  padding: 0;
  position: relative;
  width: 24px
}

.close-button:after,
.close-button:before {
  background-color: var(--colour-font);
  content: "";
  height: 2px;
  left: 0;
  position: absolute;
  transition: transform .4s, color .4s;
  width: 100%
}

.close-button:before {
  top: 0;
  transform: rotate(45deg) translate(8px, 7px)
}

.close-button:after {
  bottom: 0;
  transform: rotate(-45deg) translate(8px, -8px)
}

.close-button:hover:after,
.close-button:hover:before {
  background-color: var(--colour-primary)
}

.arrow {
  display: inline-block;
  line-height: 0;
  vertical-align: middle
}

.arrow--head {
  margin-right: 8px
}

.arrow--tail {
  margin-left: 8px
}

.icon--right {
  margin-left: 4px
}

.icon--left {
  margin-right: 4px
}

.icon-button {
  align-items: center;
  background: none;
  border: none;
  display: inline-flex;
  font-size: 16px;
  height: 40px;
  justify-content: center;
  position: relative;
  width: 40px
}

@media(max-width:820px) {
  .icon-button {
    font-size: 20px;
    height: 32px;
    width: 32px
  }
}

.icon-button:not(.icon-button:disabled) {
  cursor: pointer
}

.icon-button--small {
  height: 24px;
  width: 24px
}

.icon-button--primary {
  background-color: var(--colour-primary);
  border-radius: 50%;
  color: var(--colour-font-contrast);
  transition: transform .4s var(--ease-out-quad)
}

.icon-button--primary:disabled {
  background-color: var(--colour-font-lightest)
}

.icon-button--primary:hover:not(.icon-button--primary:disabled) {
  transform: scale(1.2)
}

.icon-button__badge {
  align-items: center;
  background-color: var(--colour-primary);
  border-radius: 50%;
  color: var(--colour-white);
  display: inline-flex;
  font-size: 11px;
  font-style: normal;
  height: 45%;
  justify-content: center;
  padding-bottom: 2px;
  position: absolute;
  right: 0;
  top: 0;
  width: 45%
}

.iframe {
  height: 0;
  margin-bottom: var(--content-space-l);
  max-width: 100%;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative
}

.iframe iframe {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%
}

.filter {
  position: relative
}

.filter__button {
  align-items: center;
  background: none;
  border: none;
  display: flex;
  justify-content: center
}

@media(max-width:820px) {
  .filter__button {
    font-size: 24px
  }
}

.filter__title {
  font-size: 1rem;
  font-weight: var(--font-weight-bold);
  margin: 0;
  padding: 8px var(--content-space);
  white-space: nowrap
}

.filter__menu {
  background-color: #fff;
  box-shadow: var(--shadow-m);
  column-gap: 30px;
  display: flex;
  max-height: 66.66vh;
  min-width: 120px;
  opacity: 0;
  padding: var(--content-space-s) 0;
  position: absolute;
  right: 0;
  top: 39px;
  transform: translateY(20px);
  visibility: hidden
}

.filter__menu[data-position=left] {
  left: 0;
  right: auto
}

@media(max-width:820px) {
  .filter__menu {
    flex-direction: column;
    overflow: scroll
  }
}

.filter__list {
  min-width: 250px;
  overflow-y: auto
}

@media(max-width:479px) {
  .filter__list {
    overflow-y: visible
  }
}

.filter__form,
.filter__item {
  padding: 8px var(--content-space)
}

.filter__item {
  cursor: pointer;
  font-size: 1rem;
  white-space: nowrap
}

.filter__item.is-selected,
.filter__item:hover {
  background-color: var(--colour-bg)
}

@media(max-width:479px) {
  .filter__item {
    font-size: 18px;
    white-space: normal
  }
}

.filter__date-label {
  display: block;
  font-size: 1rem;
  padding: 8px var(--content-space);
  width: 100%
}

.archive-list {
  border: 1px solid var(--colour-border-light);
  margin-bottom: 48px;
  max-width: 761px;
  padding: 24px
}

.archive-list__info {
  align-items: center;
  column-gap: 8px;
  display: flex;
  padding-bottom: 16px
}

.archive-list__title {
  font-weight: var(--font-weight-semibold)
}

.archive-list__icon {
  color: var(--colour-primary);
  font-size: 18px
}

.archive-list__description {
  margin-bottom: 0
}

.enhanced-list {
  list-style: none;
  padding: 0
}

.enhanced-list__item {
  align-items: center;
  border-bottom: 1px solid var(--colour-border-light);
  display: flex;
  margin: 0;
  padding: 14px 0
}

.enhanced-list__item--small {
  padding: 12px 0
}

.enhanced-list__item--no-border {
  border-bottom: 0
}

.enhanced-list__title {
  color: inherit;
  font-size: var(--font-size-l);
  margin: 0
}

.enhanced-list__title--small {
  font-size: 1rem
}

.enhanced-list__title--medium {
  font-size: 1.2rem
}

.enhanced-list__title--schedule {
  white-space: nowrap
}

.enhanced-list__icon {
  color: var(--colour-primary);
  margin-right: 1rem
}

.expandable-list {
  -ms-overflow-style: none;
  display: flex;
  list-style: none;
  overflow: auto;
  padding: 0;
  scrollbar-width: none
}

.expandable-list::-webkit-scrollbar {
  display: none
}

.expandable-list__inner {
  display: inline-flex;
  margin: 0;
  padding: 0
}

.expandable-list__inner--alt {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between
}

.expandable-list__item {
  display: flex;
  flex-shrink: 0;
  margin: 0;
  margin-right: var(--grid-gutter-space);
  max-width: 100%;
  padding: 25px 0;
  width: calc(var(--grid-width)*5 + var(--grid-gutter-space)*4)
}

@media(max-width:820px) {
  .expandable-list__item {
    padding: 1rem 0
  }
}

.expandable-list__item--vertical {
  flex-direction: column;
  row-gap: 20px;
  width: calc(var(--grid-width)*3.1 + var(--grid-gutter-space))
}

.expandable-list__item--medium {
  align-items: center;
  width: calc(var(--grid-width)*7.1 + var(--grid-gutter-space))
}

.expandable-list__picture {
  border-radius: 50%;
  flex-shrink: 0;
  height: var(--grid-width);
  margin-right: var(--grid-gutter-space);
  overflow: hidden;
  width: var(--grid-width)
}

.expandable-list__picture--position {
  height: calc(var(--grid-width)*1.5);
  width: calc(var(--grid-width)*1.5)
}

.expandable-list__picture--vertical {
  height: calc(var(--grid-width)*3.3);
  margin: 0 auto;
  width: calc(var(--grid-width)*3.3)
}

.expandable-list__picture--medium {
  height: calc(var(--grid-width)*2.16);
  width: calc(var(--grid-width)*2.16)
}

.expandable-list__title {
  margin-bottom: 0;
  margin-top: 0
}

.expandable-list__button {
  background: none;
  border: none;
  color: var(--colour-primary);
  font-size: inherit;
  font-weight: var(--font-weight-bold);
  padding-left: 3px
}

.expandable-list__button:hover {
  text-decoration: underline
}

.expandable-list__position {
  margin-bottom: 5px;
  margin-top: 0
}

.list {
  padding-left: 15px
}

.list--download {
  list-style: none
}

.list li {
  list-style-type: "–";
  text-indent: 5px
}

.pagination {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-top: 50px
}

.pagination__count-total {
  font-weight: var(--font-weight-semibold)
}

.pagination__count-total span {
  color: var(--colour-primary)
}

.pagination progress {
  appearance: none;
  background-color: #ede7dd;
  height: 3px;
  margin-bottom: 20px;
  width: 220px
}

.pagination progress[value]::-webkit-progress-bar {
  background-color: #ede7dd
}

.pagination progress[value]::-webkit-progress-value {
  background-color: var(--colour-primary)
}

.pagination__buttons {
  gap: 35px
}

.pagination__buttons[hidden=true] {
  display: none
}

.pagination__link {
  background: none;
  border: none;
  color: var(--colour-font);
  display: inline-block;
  height: 20px;
  min-width: 20px;
  padding: 4px
}

.pagination__link.is-active,
.pagination__link:hover {
  color: var(--colour-primary);
  font-weight: var(--font-weight-bold);
  pointer-events: none
}

.pagination__numbers .pagination__link {
  height: 26px
}

.pagination__link--search,
.pagination__link--search:hover,
.pagination__numbers .pagination__link.is-active,
.pagination__numbers .pagination__link:hover {
  pointer-events: all
}

.pagination__navigation-button {
  background: none;
  border: none;
  font-weight: var(--font-weight-semibold)
}

.pagination__navigation-button:hover {
  text-decoration: underline
}

.pagination--numbered {
  font-weight: var(--font-weight-semibold)
}

.pagination--numbered[hidden=true] {
  display: none
}

.pagination--numbered .pagination__numbers {
  margin: 0 20px
}

.schedule-header {
  display: flex;
  margin-bottom: 26px;
  overflow: auto;
  overflow-y: hidden
}

@media(max-width:820px) {
  .schedule-header {
    margin-bottom: 1rem
  }
}

.schedule-header__button {
  background: none;
  border: none;
  flex-shrink: 0;
  font-family: var(--font-primary);
  font-size: var(--font-size-l);
  font-weight: var(--font-weight-semibold);
  margin-right: 5%;
  opacity: .4;
  padding: 0;
  text-align: left
}

.schedule-header__button:last-of-type {
  margin-right: 0
}

.schedule-header__button.is-active,
.schedule-header__button:hover {
  opacity: 1
}

.schedule-details {
  padding-bottom: 56px
}

@media(max-width:479px) {
  .schedule-details {
    padding-bottom: 24px
  }

  .schedule-details tr {
    display: flex;
    flex-direction: column
  }
}

.schedule-details th {
  font-weight: var(--font-weight-semibold);
  padding: 20px 36px 20px 0;
  vertical-align: text-top;
  white-space: nowrap
}

@media(max-width:479px) {
  .schedule-details th {
    border-bottom: 0;
    display: block
  }
}

.schedule-details td {
  vertical-align: text-top
}

@media(max-width:479px) {
  .schedule-details td {
    display: block;
    padding-left: 24px;
    padding-top: 0
  }
}

.schedule-details td strong {
  font-weight: var(--font-weight-semibold)
}

.schedule-details__title {
  margin-bottom: 1rem;
  margin-top: 24px
}

.schedule-details__header {
  margin-bottom: 4px
}

.schedule-details__speakers {
  display: flex;
  flex-wrap: wrap;
  margin-left: -8px;
  width: calc(100% + 16px)
}

.schedule-details__speaker {
  cursor: pointer;
  display: inline-block;
  margin: 0 8px 12px;
  width: calc(33.333% - 16px)
}

.schedule-details__speaker:hover {
  text-decoration: underline
}

@media(max-width:479px) {
  .schedule-details__speaker {
    width: 100%
  }
}

.schedule-details__speakers--small .schedule-details__speaker {
  width: calc(50% - 16px)
}

.schedule-details .information__name {
  -webkit-box-orient: unset;
  -webkit-line-clamp: unset;
  display: unset
}

@media(max-width:820px) {
  .schedule-details .information__name {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    display: -webkit-box
  }
}

:root {
  --sticky-filter-gradient-right: 0;
  --sticky-filter-gradient-opacity: 0
}

.sticky-filter {
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 2
}

.sticky-filter.is-fixed {
  left: 0;
  position: fixed;
  top: var(--fixed-top);
  width: 100%
}

body.is-header-fixed.is-header-visible .sticky-filter.is-fixed {
  top: 99px
}

.sticky-filter.is-no-sticky {
  position: relative;
  top: 0 !important
}

.sticky-filter.is-with-tabs {
  padding-bottom: 0
}

.sticky-filter.is-with-tabs .sticky-filter__filters {
  padding-bottom: 18px
}

@media(max-width:820px) {
  .sticky-filter.is-with-tabs .sticky-filter__filters {
    flex-shrink: 1;
    width: 100%
  }
}

.sticky-filter__wrapper {
  background-color: #fff;
  border-bottom: 1px solid var(--colour-grey)
}

.sticky-filter.is-no-sticky .sticky-filter__wrapper {
  padding-top: 0 !important
}

.sticky-filter__inner {
  align-items: flex-end;
  display: flex;
  min-height: 60px;
  padding-top: 24px;
  position: relative
}

@media(max-width:479px) {
  .sticky-filter__inner {
    align-items: center
  }
}

.sticky-filter__title {
  margin: 0;
  padding-bottom: 8px
}

.sticky-filter__filters {
  flex-shrink: 0;
  margin-left: 24px;
  min-height: 48px
}

.sticky-filter__filter {
  flex-shrink: 0
}

.sticky-filter__clear {
  border: 1px solid var(--colour-font);
  flex-shrink: 0;
  height: 34px;
  margin: 0 1rem;
  opacity: 0;
  pointer-events: none
}

@media(max-width:820px) {
  .sticky-filter__clear {
    border-radius: 4px;
    bottom: 12px;
    font-size: 1rem;
    height: auto;
    left: 0;
    margin: auto;
    padding: 6px;
    position: fixed;
    right: 0;
    width: 80vw
  }

  .sticky-filter__clear:before {
    content: "";
    display: inline-block;
    font-family: var(--font-fontawesome);
    font-size: 1.125rem;
    font-weight: var(--font-weight-fontawesome)
  }
}

@media(max-width:820px)and (max-width:820px) {
  .sticky-filter__clear:before {
    margin-right: 8px
  }
}

.sticky-filter__clear.is-active {
  opacity: 1;
  pointer-events: auto
}

.sticky-filter-search {
  margin-right: 16px;
  width: 100%
}

@media(max-width:820px) {
  .sticky-filter-search {
    font-size: 24px;
    margin-right: 8px
  }
}

.sticky-filter-search__button {
  background: none;
  border: none;
  padding: 0
}

@media(min-width:1201px) {
  .sticky-filter-search__button {
    pointer-events: none
  }
}

.sticky-filter-search__close-button {
  background: none;
  border: none;
  padding: 0
}

.sticky-filter-search__input-container {
  width: 325px
}

@media(max-width:819px) {
  .sticky-filter-search__input-container {
    background-color: #fff;
    bottom: 0;
    display: flex;
    left: 0;
    margin: auto;
    opacity: 0;
    padding: 0 var(--content-space-m);
    position: absolute;
    right: 0;
    visibility: hidden;
    z-index: 2
  }
}

@media(max-width:479px) {
  .sticky-filter-search__input-container {
    padding: 0 var(--content-space-s)
  }
}

.sticky-filter-search__input-container.is-active {
  opacity: 1;
  visibility: visible
}

.sticky-filter-search__input {
  border: none;
  font-size: 1.5rem;
  height: 48px;
  margin-left: 8px;
  outline: none;
  padding-left: 8px;
  width: 100%
}

@media(max-width:819px) {
  .sticky-filter-search__input {
    margin-left: 0;
    padding-left: 0
  }
}

.sticky-filter-navigation {
  max-width: 100%;
  overflow: auto;
  width: 100%
}

.sticky-filter-navigation+.sticky-filter__filters {
  padding-bottom: 2px !important
}

@media(max-width:820px) {
  .sticky-filter-navigation {
    align-items: center;
    display: flex;
    height: 48px;
    margin-right: 24px;
    min-width: 100px;
    overflow: auto;
    overflow-y: hidden;
    width: 100%
  }
}

.sticky-filter-navigation__list {
  align-items: center;
  display: flex;
  list-style-type: none;
  margin: 0;
  padding: 0
}

@media(max-width:820px) {
  .sticky-filter-navigation__list {
    white-space: nowrap
  }
}

.sticky-filter-navigation__item {
  display: flex;
  margin: 0;
  padding: 0 12px
}

@media(max-width:820px) {
  .sticky-filter-navigation__item {
    padding: 0;
    width: 100%
  }
}

.sticky-filter-navigation__item:first-of-type {
  padding-left: 0
}

.sticky-filter-navigation__item:last-of-type {
  padding-right: 60px
}

.sticky-filter-navigation__item .select-filter {
  position: static
}

@media(max-width:820px) {
  .sticky-filter-navigation__item--book-prize {
    padding-right: 0
  }
}

.sticky-filter-navigation__link {
  align-items: center;
  background: none;
  border: none;
  color: var(--colour-black);
  display: inline-flex;
  font-size: 1.5rem;
  height: 52px;
  overflow: hidden;
  position: static !important;
  text-overflow: ellipsis;
  white-space: nowrap
}

@media(max-width:820px) {
  .sticky-filter-navigation__link {
    display: inline-flex;
    font-size: 18px;
    padding: 8px var(--content-space-s);
    text-align: left;
    width: 100%
  }

  .sticky-filter-navigation__link.is-selected,
  .sticky-filter-navigation__link:hover {
    background-color: var(--colour-bg)
  }
}

@media(max-width:480px) {
  .sticky-filter-navigation__link {
    padding: 8px var(--content-space-s)
  }
}

.sticky-filter-navigation__indicator {
  background-color: var(--colour-primary);
  bottom: -1px;
  height: 4px;
  left: 0;
  position: absolute;
  width: 20px
}

@media(max-width:820px) {
  .sticky-filter-navigation__indicator {
    display: none
  }
}

.sticky-filter-navigation__tools {
  display: flex
}

.sticky-filter-navigation__tools--book-prize {
  justify-content: space-between;
  margin-right: 0;
  overflow-x: visible;
  width: 100%
}

@media(max-width:820px) {
  .sticky-filter-navigation__tools--book-prize {
    align-items: center
  }
}

.sticky-filter-navigation--alt {
  margin-right: 24px;
  overflow: auto;
  padding-right: 24px;
  position: static
}

.sticky-filter-navigation--alt:after,
.sticky-filter-navigation:after {
  background: linear-gradient(90deg, hsla(0, 0%, 100%, 0), #fff);
  bottom: 0;
  content: "";
  left: var(--sticky-filter-gradient-right);
  opacity: var(--sticky-filter-gradient-opacity);
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 120px;
  z-index: 2
}

.sticky-filter-select {
  min-width: 100px;
  padding: 0 6px;
  position: relative
}

@media(max-width:820px) {
  .sticky-filter-select {
    align-self: center;
    margin: 0 24px 0 0
  }
}

.sticky-filter-select:before {
  align-items: center;
  color: var(--colour-primary);
  content: "";
  display: flex;
  font-family: var(--font-fontawesome);
  font-weight: var(--font-weight-fontawesome);
  height: 100%;
  position: absolute;
  right: 0;
  transition: all .4s ease-in-out
}

.sticky-filter-select.active:before {
  transform: rotate(180deg)
}

.sticky-filter-select__value {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: 1.5rem;
  height: 52px;
  min-width: 100px;
  padding-right: 24px;
  padding-top: 1px;
  position: relative;
  width: 100%;
  z-index: 1
}

.sticky-filter-select__button {
  flex-shrink: 0;
  font-size: 1.5rem;
  padding-bottom: 0;
  padding-top: 0
}

.sticky-filter-navigation-mobile {
  align-self: center;
  margin-right: 24px;
  min-width: 100px;
  position: relative;
  width: 100%
}

@media(min-width:820px) {
  .sticky-filter-navigation-mobile {
    display: none
  }
}

.sticky-filter-navigation-mobile:before {
  align-items: center;
  color: var(--colour-primary);
  content: "";
  display: flex;
  font-family: var(--font-fontawesome);
  font-weight: var(--font-weight-fontawesome);
  height: 100%;
  position: absolute;
  right: 0
}

.sticky-filter-navigation-mobile__value {
  align-items: center;
  cursor: pointer;
  display: flex;
  height: 40px;
  min-width: 100px;
  padding-right: 20px;
  width: 100%
}

.sticky-filter-navigation-mobile .filter__menu {
  left: 0
}

.table {
  width: 100%
}

.table__head {
  border-bottom: 1px solid var(--colour-border-light);
  font-size: var(--font-size-semibold);
  padding: 20px 12px;
  text-align: left
}

.table__head--condensed {
  padding: 12px
}

.table__cell {
  border-bottom: 1px solid var(--colour-border-light);
  padding: 20px 12px
}

.table__cell--condensed {
  padding: 12px
}

tr {
  border-bottom: 1px solid var(--colour-border-light)
}

th {
  font-size: var(--font-size-semibold);
  text-align: left
}

td,
th {
  padding: 20px 12px
}

table {
  border-collapse: collapse;
  width: 100%
}

table.is-condensed td,
table.is-condensed th {
  padding: 12px
}

.step-progress-bar {
  --progress-circle-height: 44px;
  margin: 75px 0;
  position: relative
}

@media(max-width:820px) {
  .step-progress-bar {
    --progress-circle-height: 37px;
    margin-bottom: 64px
  }
}

.step-progress-bar__wrapper--is-multiple {
  height: 100%;
  margin: 70px 0 24px;
  position: relative
}

.step-progress-bar__list {
  display: flex;
  justify-content: space-around;
  margin: 0;
  padding: 0
}

@media(max-width:820px) {
  .step-progress-bar__list {
    display: block
  }
}

.step-progress-bar__list--vertical {
  flex-direction: column;
  gap: 100px
}

.step-progress-bar__list--multiple {
  gap: 50px
}

.step-progress-bar__progress {
  align-items: center;
  display: flex;
  flex-direction: column;
  list-style: none;
  margin-bottom: 0;
  margin-top: -20px;
  padding: 0;
  position: relative
}

@media(max-width:820px) {
  .step-progress-bar__progress {
    align-items: center;
    display: flex;
    flex-direction: row;
    padding: 1.25rem 0
  }
}

.step-progress-bar__progress--vertical {
  column-gap: 25px;
  display: flex;
  flex-direction: row
}

.step-progress-bar__icon {
  align-items: center;
  background-color: #ede7dd;
  border-radius: 50%;
  display: flex;
  flex-shrink: 0;
  height: var(--progress-circle-height);
  justify-content: center;
  list-style: none;
  margin-bottom: 0;
  position: relative;
  width: var(--progress-circle-height)
}

.step-progress-bar__icon:before {
  color: #fff;
  content: "";
  font-family: var(--font-fontawesome);
  font-weight: var(--font-weight-fontawesome)
}

.step-progress-bar__progress.is-active .step-progress-bar__icon {
  background-color: var(--colour-primary)
}

.step-progress-bar__content {
  margin-top: 20px;
  text-align: center;
  width: 150px
}

@media(max-width:820px) {
  .step-progress-bar__content {
    left: 0;
    margin-left: var(--content-space);
    margin-top: 0;
    position: relative;
    text-align: left;
    transform: none;
    width: auto
  }
}

.step-progress-bar__content--vertical {
  left: 0;
  margin-top: 0;
  position: relative;
  text-align: left;
  transform: none;
  width: unset
}

.step-progress-bar__title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: 0
}

.step-progress-bar__description {
  margin-bottom: 0
}

.step-progress-bar__indicator {
  background-color: #ede7dd;
  height: 4px;
  position: absolute;
  width: 100%
}

@media(max-width:820px) {
  .step-progress-bar__indicator {
    height: 100%;
    left: calc(var(--progress-circle-height)/2);
    width: 4px
  }
}

.step-progress-bar__indicator--bar {
  background-color: var(--colour-primary);
  display: block;
  height: 4px;
  width: 70%
}

@media(max-width:820px) {
  .step-progress-bar__indicator--bar {
    width: 4px
  }
}

.step-progress-bar__indicator--vertical {
  height: 100%;
  left: 20px;
  width: 4px
}

.step-progress-bar__indicator--bar-vertical {
  width: 100%
}

.select-filter {
  min-width: 100px;
  position: relative
}

@media(max-width:820px) {
  .select-filter {
    align-self: center;
    margin: 0
  }
}

.select-filter__value {
  align-items: center;
  cursor: pointer;
  display: flex;
  height: 52px;
  justify-content: space-between;
  min-width: 100px;
  position: relative;
  width: 100%;
  z-index: 1
}

.select-filter__value:after {
  align-items: center;
  color: var(--colour-font);
  content: "";
  display: flex;
  font-family: var(--font-fontawesome);
  font-weight: var(--font-weight-fontawesome);
  height: 100%;
  margin-left: 12px;
  transition: all .4s ease-in-out
}

.select-filter__value--bordered {
  border: 1px solid var(--colour-font);
  padding-left: 12px;
  padding-right: 48px
}

.select-filter__value--bordered:before {
  right: 8px
}

.select-filter__title {
  font-size: 1rem;
  font-weight: var(--font-weight-bold);
  margin: 0;
  padding: 8px var(--content-space);
  white-space: nowrap
}

.select-filter__list {
  background-color: #fff;
  box-shadow: var(--shadow-m);
  left: 0;
  max-height: 66.66vh;
  max-width: 100vw;
  min-width: 120px;
  opacity: 0;
  overflow: auto;
  padding: var(--content-space-s) 0;
  position: absolute;
  top: 76px;
  transform: translateY(20px) scale(0);
  visibility: hidden;
  z-index: 2
}

.select-filter__list.is-alt {
  overflow: inherit
}

.select-filter__list.is-nested-open {
  overflow: hidden
}

.select-filter__list[data-position=left] {
  left: 0;
  right: auto
}

@media(max-width:820px) {
  .select-filter__list {
    flex-direction: column;
    overflow: scroll
  }
}

@media(max-width:480px) {
  .select-filter__list {
    width: 100%
  }
}

.select-filter__item {
  font-size: 1rem;
  white-space: nowrap
}

@media(max-width:479px) {
  .select-filter__item {
    font-size: 18px
  }
}

.select-filter__button {
  background: none;
  border: none;
  min-width: 100%;
  padding: 8px var(--content-space);
  text-align: left
}

.select-filter__button.is-selected,
.select-filter__button:hover {
  background-color: var(--colour-bg)
}

.select-filter__back {
  background: none;
  border: none;
  font-weight: 600;
  padding: 8px var(--content-space);
  text-align: left;
  width: 100%
}

.select-filter__nested-list {
  background-color: #fff;
  box-shadow: var(--shadow-m);
  display: none;
  height: 100%;
  left: 0;
  opacity: 0;
  overflow: auto;
  padding: var(--content-space-s) 0;
  position: absolute;
  top: 0;
  transform: translateX(20px);
  visibility: hidden;
  width: 100%
}

.select-filter__inner {
  padding: 0 24px
}

.select-filter.is-active>.select-filter__value:after {
  transform: scaleY(-1)
}

.select-filter .select-filter {
  position: relative
}

.select-filter .select-filter .select-filter__list {
  transform: none !important
}

.modal {
  align-items: center;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  height: 100%;
  justify-content: center;
  left: 0;
  opacity: 0;
  padding: 10vh;
  position: fixed;
  top: var(--fixed-top);
  touch-action: pinch-zoom;
  visibility: hidden;
  width: 100%;
  z-index: 11
}

@media(max-width:820px) {
  .modal {
    padding: 10vh 32px
  }
}

@media(max-width:479px) {
  .modal {
    -webkit-user-drag: element !important;
    padding: 0;
    touch-action: pinch-zoom !important
  }
}

.modal__inner {
  background-color: #fff;
  border-radius: 20px;
  max-height: 90vh;
  max-width: 1280px;
  min-height: 20vh;
  overflow: auto;
  padding: 50px 42px;
  position: relative;
  width: 100%;
  z-index: 2
}

.modal__inner--small {
  max-width: 872px
}

@media(max-width:479px) {
  .modal__inner {
    max-height: 100vh;
    padding: 50px 24px
  }
}

.modal__image {
  max-height: 100%;
  z-index: 2
}

.modal__button {
  background-color: transparent;
  border: none;
  color: transparent;
  cursor: pointer;
  height: 24px;
  justify-self: center;
  margin-left: auto;
  outline: none;
  padding: 0;
  position: absolute;
  right: 16px;
  top: 16px;
  width: 24px;
  z-index: 10
}

.modal__button:after,
.modal__button:before {
  background-color: var(--colour-font);
  content: "";
  height: 2px;
  left: 0;
  position: absolute;
  transition: transform .4s, color .4s;
  width: 100%
}

.modal__button:before {
  top: 0;
  transform: rotate(45deg) translate(8px, 7px)
}

.modal__button:after {
  bottom: 0;
  transform: rotate(-45deg) translate(8px, -8px)
}

.modal__button:hover:after,
.modal__button:hover:before {
  background-color: var(--colour-primary)
}

.modal__overlay {
  background-color: #000;
  height: 100%;
  left: 0;
  opacity: .6;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1
}

.modal__nav {
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 0;
  height: 4rem;
  margin: auto;
  max-height: 64px;
  max-width: 64px;
  position: absolute;
  top: 0;
  transition: transform .4s;
  width: 4rem;
  z-index: 2
}

.speaker-modal__info {
  display: flex
}

@media(max-width:820px) {
  .speaker-modal__info {
    flex-direction: column
  }
}

.speaker-modal__avatar {
  background-color: #ccc;
  border-radius: 50%;
  flex-shrink: 0;
  height: 160px;
  margin-right: 24px;
  overflow: hidden;
  width: 160px
}

@media(max-width:820px) {
  .speaker-modal__avatar {
    margin-bottom: 24px
  }
}

.speaker-modal__title {
  margin-bottom: 8px;
  margin-top: 0
}

.speaker-modal__subtitle {
  font-weight: 700
}

.accordion {
  margin-bottom: 20px
}

.accordion__item--alt,
.accordion__item--simplified {
  border-bottom: none
}

.accordion__title {
  align-items: center;
  background: none;
  border: none;
  border-bottom: 3px solid var(--colour-border-light);
  cursor: pointer;
  display: flex;
  font-size: var(--font-size-l);
  font-weight: var(--font-weight-semibold);
  justify-content: space-between;
  margin: auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2);
  padding: 20px var(--content-space);
  text-align: left;
  width: 100%
}

@media(max-width:479px) {
  .accordion__title {
    font-size: var(--font-size-m)
  }
}

.accordion__title--alt {
  border-bottom: 3px solid var(--colour-border-light)
}

.accordion__title--simplified {
  border-bottom: none;
  justify-content: flex-start
}

.accordion__title--simplified.is-active:after,
.accordion__title--simplified:after {
  content: none
}

.accordion__label--simplified {
  align-items: center;
  display: inline-flex
}

.accordion__label--time {
  white-space: nowrap
}

.accordion__action {
  align-items: center;
  display: inline-flex
}

.accordion__extra {
  margin-right: 1rem;
  padding-left: 30px;
  white-space: nowrap
}

.accordion__icon {
  display: inline-block;
  font-style: normal;
  height: 24px;
  margin-right: 12px;
  position: relative;
  width: 24px
}

.accordion__icon:after,
.accordion__icon:before {
  background-color: var(--colour-primary);
  bottom: 0;
  content: "";
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  transition: transform .4s, opacity .4s
}

.accordion__icon:before {
  height: 3px;
  width: 24px
}

.accordion__title.is-active .accordion__icon:before {
  transform: rotate(180deg)
}

.accordion__icon:after {
  height: 24px;
  width: 3px
}

.accordion__title.is-active .accordion__icon:after {
  opacity: 0;
  transform: rotate(90deg)
}

.accordion__icon--simplified:before {
  width: 16px
}

.accordion__icon--simplified:after {
  height: 16px
}

.accordion__content {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transition: all .3s
}

.accordion__content--alt {
  padding-top: 20px
}

.accordion__content.is-active {
  opacity: 1;
  pointer-events: auto
}

.accordion__time-title {
  display: flex;
  gap: 20px
}

.horizontal-accordion {
  display: flex;
  margin-bottom: 20px;
  width: 100%
}

.horizontal-accordion__collection {
  display: flex;
  overflow: hidden;
  width: 100%
}

@media(max-width:820px) {
  .horizontal-accordion__collection {
    flex-shrink: 0;
    overflow: auto
  }
}

.horizontal-accordion__list {
  display: flex;
  flex-shrink: 0;
  width: 100%
}

@media(max-width:820px) {
  .horizontal-accordion__list {
    width: auto
  }
}

.horizontal-accordion__item {
  align-items: flex-end;
  background-color: var(--colour-secondary);
  color: var(--colour-white);
  cursor: pointer;
  display: flex;
  height: 706px;
  overflow: hidden;
  padding: var(--content-space-m);
  position: relative;
  transition: width .4s, transform .4s;
  width: 20%;
  z-index: 0
}

.horizontal-accordion__item.is-active {
  cursor: auto;
  flex-shrink: 0
}

@media(min-width:821px) {
  .horizontal-accordion__item.is-active {
    width: 40% !important
  }
}

.horizontal-accordion__item.is-active:before {
  backdrop-filter: blur(10px);
  background-color: rgba(0, 0, 0, .1);
  content: "";
  height: 100%;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transition: opacity .2s;
  width: 100%;
  z-index: -1
}

.horizontal-accordion__item.is-active:hover:before {
  opacity: 1
}

.horizontal-accordion__item:after {
  background: linear-gradient(180deg, transparent 30%, rgba(0, 0, 0, .46) 60%);
  content: "";
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1
}

.horizontal-accordion__item--plain {
  color: var(--colour-font);
  cursor: auto;
  flex-shrink: 0;
  padding: 1rem;
  width: 16.666%
}

.horizontal-accordion__item--plain:after {
  content: none
}

@media(max-width:820px) {
  .horizontal-accordion__item {
    flex-shrink: 0;
    width: 48vw
  }
}

@media(max-width:479px) {
  .horizontal-accordion__item {
    width: 70vw !important
  }
}

.horizontal-accordion__image {
  height: 100%;
  left: 0;
  object-fit: cover;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -2
}

@media(min-width:821px) {
  .horizontal-accordion__content {
    opacity: 0;
    transform: translateY(20px);
    visibility: hidden
  }
}

.horizontal-accordion__title {
  align-items: center;
  display: flex;
  font-size: 25px;
  font-weight: var(--font-weight-semibold);
  justify-content: space-between;
  margin-top: 4px;
  opacity: 1 !important;
  width: 100%
}

@media(max-width:820px) {
  .horizontal-accordion__title {
    transform: none
  }
}

.horizontal-accordion__alt-title {
  margin: 1rem 0 0
}

.horizontal-accordion__tag {
  font-weight: var(--font-weight-semibold)
}

.horizontal-accordion__date {
  margin-bottom: .625em
}

.horizontal-accordion__link {
  color: var(--colour-white);
  pointer-events: none
}

.horizontal-accordion__link>* {
  opacity: 0;
  transform: translateY(3rem);
  transition: transform .4s
}

@media(max-width:820px) {
  .horizontal-accordion__link>* {
    opacity: 1;
    transform: none
  }
}

.horizontal-accordion__item:hover .horizontal-accordion__link>* {
  opacity: 1;
  transform: translateY(0)
}

.horizontal-accordion__item:hover .horizontal-accordion__link {
  pointer-events: auto
}

.horizontal-accordion__link-text {
  color: inherit;
  display: block;
  transition-delay: .1s
}

.horizontal-accordion__button {
  align-items: center;
  background-color: var(--colour-primary);
  border: none;
  color: var(--colour-white);
  display: flex;
  font-size: 20px;
  height: 62px;
  justify-content: center;
  width: 62px
}

.horizontal-accordion__button:hover {
  text-decoration: none
}

.checkbox {
  display: inline-block;
  position: relative
}

.checkbox.is-disabled {
  color: var(--colour-font-lighter)
}

.checkbox__checkmark {
  align-items: center;
  background-color: #fff;
  border: 1px solid var(--colour-border);
  bottom: 0;
  display: flex;
  height: 24px;
  justify-content: center;
  left: 0;
  margin: auto;
  position: absolute;
  top: 0;
  width: 24px
}

.checkbox__checkmark:after {
  content: "";
  display: none;
  height: 12px;
  width: 12px
}

.checkbox__checkmark--book-prize {
  opacity: 0
}

.checkbox__input {
  background-color: transparent;
  border: 1px solid #000;
  display: inline-block;
  height: 24px;
  position: absolute;
  visibility: hidden;
  width: 24px
}

.checkbox__input:checked~.checkbox__checkmark:after {
  background-color: var(--colour-primary);
  display: block
}

.checkbox__input:disabled~.checkbox__checkmark {
  background-color: var(--colour-light-grey)
}

.checkbox__label {
  display: inline-block;
  padding-left: 30px;
  position: relative
}

.checkbox__label--book-prize {
  font-size: 1.5rem
}

.form__legend {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.form__legend.is-required:after {
  color: var(--colour-primary);
  content: "*";
  display: inline-block;
  margin-left: 4px
}

.form__section {
  margin: 40px 0
}

.form__row {
  display: flex;
  margin-bottom: 1rem
}

.form__row--centered {
  justify-content: center
}

.form__row>:first-child {
  margin-right: var(--grid-gutter-space)
}

.form__row>:last-child {
  margin-right: 0
}

.form__fieldset {
  display: flex;
  flex-wrap: wrap
}

.form__fieldset>* {
  margin-right: var(--grid-gutter-space)
}

.form__fieldset>:last-child {
  margin-right: 0
}

.form__fieldset--vertical {
  flex-direction: column
}

.form__fieldset--vertical>* {
  margin-bottom: 12px
}

.form__fieldset--vertical>:last-child {
  margin-bottom: 0
}

.form__label {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.form__label.is-required:after {
  color: var(--colour-primary);
  content: "*";
  display: inline-block;
  margin-left: 4px
}

.form__input,
.form__select {
  border: 1px solid var(--colour-border);
  height: 50px;
  width: 100%
}

.form__input.is-error,
.form__select.is-error {
  border-color: var(--colour-error)
}

.form__message {
  font-size: 13px;
  margin: 4px 0;
  width: 100%
}

.form__message.is-error {
  color: var(--colour-error)
}

.form--centered {
  margin: 0 auto;
  max-width: 800px
}

.form--centered .form__row>div {
  width: 100%
}

.form--sc label {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.form--sc input:not([type=submit], [type=radio]) {
  border: 1px solid var(--colour-border);
  font-size: 1rem;
  height: 50px;
  min-width: 240px;
  padding: calc(var(--content-space)/2);
  width: 100%
}

.form--sc textarea {
  min-height: 140px;
  min-width: 320px;
  width: 100%
}

.form--naked label {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.form--naked .checkbox,
.form--naked .radio {
  align-items: center;
  display: flex
}

.form--naked .checkbox__label,
.form--naked .radio__label {
  font-weight: 400
}

.form--naked .checkbox__label:after,
.form--naked .radio__label:after {
  align-items: center;
  background-color: #fff;
  border: 1px solid var(--colour-border);
  content: "";
  display: flex;
  height: 24px;
  justify-content: center;
  left: 0;
  position: absolute;
  top: 0;
  width: 24px
}

.form--naked .checkbox__input:checked:after,
.form--naked .radio__input:checked:after {
  background-color: var(--colour-primary);
  content: "";
  height: 12px;
  left: -27px;
  position: absolute;
  top: 4px;
  visibility: visible;
  width: 12px;
  z-index: 10
}

.form--naked .radio__label {
  font-weight: 400
}

.form--naked .radio__label:after {
  border-radius: 50%
}

.form--naked .radio__input:checked:after {
  border-radius: 50%;
  left: -28px
}

.form--naked input:not([type=submit], [type=radio], [type=checkbox]),
.form--naked select:not([type=submit], [type=radio], [type=checkbox]) {
  border: 1px solid var(--colour-border);
  font-size: 1rem;
  height: 50px;
  margin-bottom: 20px;
  min-width: 240px;
  padding: calc(var(--content-space)/2);
  width: 100%
}

.form--naked input[type=submit] {
  align-items: center;
  background-color: var(--colour-white);
  background-color: var(--colour-primary);
  border: none;
  color: var(--colour-white);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 600;
  justify-content: center;
  margin-top: 20px;
  padding: 15px 24px;
  position: relative;
  transition: opacity .1s ease, transform .4s ease
}

.form--naked input[type=submit]:hover {
  opacity: .9;
  transform: translateY(-2px) scale(.98)
}

.form--naked input[type=checkbox],
.form--naked input[type=radio] {
  font-size: 16px;
  height: 24px;
  margin-right: 10px;
  width: 24px
}

.form--naked textarea {
  min-height: 140px;
  min-width: 320px;
  width: 100%
}

.form--naked span.field-validation-error {
  color: red;
  display: block;
  margin-top: -15px;
  padding-bottom: 10px
}

.radio {
  display: inline-block;
  position: relative
}

.radio.is-disabled {
  color: var(--colour-font-lighter)
}

.radio__checkmark {
  align-items: center;
  border: 1px solid var(--colour-border);
  border-radius: 50%;
  display: flex;
  height: 24px;
  justify-content: center;
  left: 0;
  position: absolute;
  top: 0;
  width: 24px
}

.radio__checkmark:after {
  border-radius: 50%;
  content: "";
  display: none;
  height: 12px;
  width: 12px
}

.radio__input {
  background-color: transparent;
  border: 1px solid #000;
  display: inline-block;
  height: 24px;
  position: absolute;
  visibility: hidden;
  width: 24px
}

.radio__input:checked~.radio__checkmark:after {
  background-color: var(--colour-primary);
  display: block
}

.radio__input:disabled~.radio__checkmark {
  background-color: var(--colour-light-grey)
}

.radio__label {
  display: inline-block;
  padding-left: 30px;
  position: relative
}

.select {
  width: calc(50% - var(--grid-gutter-space)/2)
}

.select__input {
  appearance: none;
  background: transparent;
  background-image: url("data:image/svg+xml;utf8,<svg fill='black' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");
  background-position: top 50% right 8px;
  background-repeat: no-repeat;
  border: 1px solid var(--colour-border);
  font-size: 1rem;
  height: 50px;
  min-width: 240px;
  padding: calc(var(--content-space)/2);
  width: 100%
}

.select__input.is-error {
  border-color: var(--colour-error)
}

.select__input:disabled {
  background-color: var(--colour-light-grey)
}

.select__label {
  display: flex;
  flex-direction: column
}

.select__label-text {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.select__label-text.is-required:after {
  color: var(--colour-primary);
  content: "*";
  display: inline-block;
  margin-left: 4px
}

.switch {
  display: inline-block;
  height: 24px;
  position: relative;
  width: 44px
}

.switch__slider {
  background-color: #ccc;
  border-radius: 24px;
  bottom: 0;
  cursor: pointer;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: .4s
}

.switch__slider:before {
  background-color: #fff;
  border-radius: 50%;
  bottom: 4px;
  content: "";
  height: 16px;
  left: 4px;
  position: absolute;
  transition: .4s;
  width: 16px
}

.switch__input {
  height: 0;
  opacity: 0;
  width: 0
}

.switch__input:checked+.switch__slider {
  background-color: var(--colour-primary)
}

.switch__input:checked+.switch__slider:before {
  transform: translateX(20px)
}

.switch__input:focus+.switch__slider {
  box-shadow: 0 0 1px var(--colour-primary)
}

.text-field {
  width: calc(50% - var(--grid-gutter-space)/2)
}

.text-field--long {
  width: 100%
}

.text-field__input {
  border: none;
  font-size: 1rem;
  height: 50px;
  min-width: 240px;
  padding: calc(var(--content-space)/2);
  width: 100%
}

.text-field__input.is-error {
  border-color: var(--colour-error)
}

.text-field__input:disabled {
  background-color: var(--colour-light-grey)
}

.text-field__input--textarea {
  min-height: 140px;
  min-width: 320px;
  width: 100%
}

.text-field__input--outlined {
  border: 1px solid var(--colour-border)
}

.text-field__label {
  display: flex;
  flex-direction: column;
  width: 100%
}

.text-field__label-text {
  display: inline-block;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 10px;
  width: 100%
}

.text-field__label-text.is-required:after {
  color: var(--colour-primary);
  content: "*";
  display: inline-block;
  margin-left: 4px
}

:root .typeahead {
  display: flex
}

@media(max-width:820px) {
  :root .typeahead {
    border-bottom: none;
    flex-wrap: wrap
  }
}

:root .typeahead__input {
  margin-left: 0;
  padding-left: 0
}

:root .typeahead__button {
  margin-left: auto
}

@media(max-width:820px) {
  :root .typeahead__button {
    width: 50%
  }
}

:root .typeahead__select {
  background-color: var(--white);
  border: none;
  font-size: 1rem;
  margin-left: auto;
  margin-right: var(--grid-gutter-space)
}

@media(max-width:820px) {
  :root .typeahead__select {
    margin-right: 0;
    width: 50%
  }
}

.twitter-typeahead {
  display: flex;
  flex-basis: 100%;
  margin-right: var(--grid-gutter-space)
}

@media(max-width:820px) {
  .twitter-typeahead {
    border-bottom: 1px solid var(--colour-grey);
    margin-bottom: 10px
  }
}

.tt-menu {
  background-clip: padding-box;
  background-color: #fff;
  border: 1px solid rgba(0, 0, 0, .15);
  border-radius: 4px;
  box-shadow: 0 6px 12px rgba(0, 0, 0, .176);
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  padding-bottom: 5px
}

.tt-menu .suggestions {
  padding: 15px;
  width: 33.333%
}

@media(max-width:820px) {
  .tt-menu .suggestions {
    width: 100%
  }
}

.tt-menu .tt-suggestion {
  margin-left: 0
}

.tt-menu .autocompletion-header {
  font-size: 1.4rem;
  font-weight: var(--font-weight-semibold)
}

.tt-menu .globalSuggested_title,
.tt-menu .suggested_title {
  font-size: 1.125rem
}

.tt-menu .suggested_link {
  color: var(--colour-black)
}

.tt-menu .suggested_link:hover {
  color: var(--colour-primary)
}

.tt-open {
  display: flex !important
}

.tt-empty,
.tt-open.tt-empty {
  display: none !important
}

.avatar {
  border-radius: 50%;
  height: 184px;
  overflow: hidden;
  width: 184px
}

.avatar--small {
  height: 95px;
  width: 95px
}

.avatar--extra-small {
  height: 60px;
  width: 60px
}

.avatar__figure,
.avatar__image {
  height: 100%;
  object-fit: cover;
  width: 100%
}

.carousel {
  cursor: grab;
  display: flex;
  height: 100%;
  overflow: hidden;
  position: relative;
  width: 100%
}

.carousel__wrapper {
  flex-shrink: 0;
  opacity: .5;
  user-select: none
}

.carousel__wrapper.is-active {
  opacity: 1
}

.carousel__wrapper:last-of-type {
  margin-right: 200px;
  max-width: none;
  width: 100%
}

.carousel__item {
  align-items: center;
  display: flex
}

.carousel:active {
  cursor: grabbing
}

.category-tag {
  align-items: center;
  background-color: #fff;
  color: var(--colour-font);
  display: flex;
  justify-content: center;
  min-height: 32px;
  padding: 2px 12px;
  white-space: nowrap
}

.category-tag--outline {
  background: none;
  border: 1px solid var(--colour-font);
  color: inherit
}

.dropdown-menu {
  background-color: #fff;
  box-shadow: var(--shadow-m);
  color: var(--colour-font);
  display: none;
  left: 0;
  margin: auto;
  max-height: calc(90vh - 120px);
  max-width: 100%;
  position: fixed;
  right: 0;
  top: var(--layout-header-height);
  width: var(--content-width-inner)
}

@media only screen and (min-width:1080px) {
  .dropdown-menu {
    overflow: hidden
  }
}

@media only screen and (max-width:1080px) {
  .dropdown-menu {
    box-shadow: none;
    height: 100%;
    max-height: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2
  }
}

.header.is-fixed .dropdown-menu {
  top: 100px
}

.dropdown-menu.is-active {
  display: flex
}

.dropdown-menu--small {
  padding: 30px;
  width: 260px
}

@media only screen and (max-width:1080px) {
  .dropdown-menu--small {
    height: 100%;
    width: 100%
  }
}

.dropdown-menu__inner {
  height: 100%;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__inner {
    padding: 16px 30px 32px
  }
}

.dropdown-menu__inner--alt {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(12, 1fr);
  justify-content: space-between;
  overflow: auto
}

@media(max-width:479px) {
  .dropdown-menu__inner--alt {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__inner--alt {
    display: block
  }
}

.dropdown-menu__section {
  display: flex;
  justify-content: space-between;
  padding: 45px 80px;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__section {
    display: block;
    padding: 0 0 1px
  }
}

.dropdown-menu__section--alt {
  align-content: flex-start;
  flex-wrap: wrap;
  grid-column: 6/13;
  padding: 40px;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__section--alt {
    display: block;
    margin-top: 18px;
    padding: 0
  }
}

.dropdown-menu__collection {
  width: 100%
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__collection {
    margin-bottom: var(--content-space-head)
  }
}

.dropdown-menu__list h4 {
  font-size: 20px
}

@media(max-width:820px) {
  .dropdown-menu__list h4 {
    font-size: var(--font-size-h4-mobile)
  }
}

.dropdown-menu__list h4 a,
.dropdown-menu__list h4 a:last-of-type {
  padding-bottom: 0
}

.dropdown-menu__list--alt {
  width: 50%
}

.dropdown-menu__list--alt h4 {
  margin: 0 0 16px
}

.dropdown-menu__list--alt a:last-of-type {
  padding-bottom: 28px
}

.dropdown-menu__title {
  margin-bottom: var(--content-space)
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__title {
    margin-bottom: calc(var(--content-space-head)/2)
  }
}

.dropdown-menu__link {
  color: var(--colour-font);
  display: block;
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0;
  padding-bottom: 8px
}

.dropdown-menu__link:hover {
  color: var(--colour-primary)
}

.dropdown-menu__link--all {
  font-weight: 800
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__link--all {
    display: inline-block;
    font-family: var(--font-secondary);
    font-size: var(--font-size-l);
    font-weight: 400;
    letter-spacing: .15px;
    margin-bottom: 8px
  }
}

.dropdown-menu__back {
  background: none;
  border: none;
  display: none
}

@media only screen and (max-width:1080px) {
  .dropdown-menu__back {
    display: block;
    padding: 0
  }
}

.dropdown-sub-menu {
  background-color: var(--colour-primary);
  color: var(--colour-white);
  display: flex;
  flex-direction: column;
  grid-column: 1/6;
  justify-content: center;
  max-height: calc(90vh - 120px);
  padding: 24px 80px;
  position: sticky;
  top: 0
}

@media only screen and (max-width:1080px) {
  .dropdown-sub-menu {
    display: none
  }
}

.dropdown-sub-menu__container {
  display: flex;
  grid-column: 7/13;
  height: 386px;
  max-height: calc(90vh - 120px);
  position: sticky;
  top: 0
}

.dropdown-menu-mobile-title {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-bold)
}

.dropdown-menu-mobile-title__arrow {
  font-size: 20px;
  margin-right: 12px
}

.hero {
  align-items: center;
  background-position: 50%;
  background-size: cover;
  color: var(--colour-white);
  display: flex;
  min-height: 682px;
  width: 100%
}
.bg-box {
  background-image: url('../images/DES8801_Website transformation project_images_New.jpg')
}

.hero.is-light {
  color: var(--colour-font)
}

.hero__inner {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-auto-rows: auto;
  grid-template-columns: repeat(12, 1fr);
  height: 100%;
  justify-content: space-between;
  min-height: 682px;
  padding-top: calc(var(--layout-header-height) + 80px);
  position: relative
}

@media(max-width:479px) {
  .hero__inner {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media(max-width:820px) {
  .hero__inner {
    padding-top: var(--layout-header-height)
  }
}

.hero__inner--grant {
  padding-top: calc(var(--layout-header-height) + 80px)
}

@media(max-width:820px) {
  .hero__inner--grant {
    padding-top: 10rem
  }

  .hero__inner {
    padding-bottom: 2rem
  }
}

.hero__text {
  align-self: center;
  grid-column: 1/6;
  padding-bottom: 5rem
}

@media(max-width:820px) {
  .hero__text {
    grid-column: 1/13;
    margin-bottom: 1.5em;
    padding-bottom: 0
  }
}

@media(max-width:479px) {
  .hero__text {
    grid-column: 1/5
  }
}

.hero__title {
  margin-bottom: 13px
}

.hero__subtitle {
  margin-bottom: var(--content-space);
  margin-top: 0
}

.hero__breadcrumb {
  margin-bottom: 12px
}

.hero__sub {
  align-self: center;
  grid-column: 7/13
}

@media(max-width:820px) {
  .hero__sub {
    grid-column: 1/13
  }
}

@media(max-width:479px) {
  .hero__sub {
    grid-column: 1/5
  }
}

.hero__card-container {
  grid-column: 9/13
}

@media(max-width:820px) {
  .hero__card-container {
    grid-column: 1/13
  }
}

@media(max-width:479px) {
  .hero__card-container {
    grid-column: 1/5
  }
}

.hero__card-container,
.hero__video-container {
  align-self: flex-end;
  justify-self: flex-end
}

.hero__video-container {
  grid-column: 6/13;
  max-width: 650px;
  width: 100%
}

@media(max-width:820px) {
  .hero__video-container {
    background-color: transparent;
    grid-column: 1/13;
    justify-content: start;
    justify-self: start;
    margin-top: 30px;
    width: 100%
  }
}

@media(max-width:479px) {
  .hero__video-container {
    grid-column: 1/5;
    width: 100%
  }
}

.hero__video-container .card--video-live {
  min-width: 100%
}

.hero__video-container--youtube .card:before {
  display: none
}

.hero__image-container {
  grid-column: 9/13;
  margin-bottom: -90px;
  margin-top: 90px;
  position: relative;
  width: 428px
}

@media(max-width:1080px) {
  .hero__image-container {
    width: 350px
  }
}

@media(max-width:820px) {
  .hero__image-container {
    bottom: 0;
    grid-column: 1/13;
    height: 100%;
    left: 0;
    margin: 0;
    position: relative;
    transform: none;
    width: 100%
  }
}

@media(max-width:479px) {
  .hero__image-container {
    grid-column: 1/5
  }
}

.hero__image {
  height: 100%;
  object-fit: cover;
  width: 100%
}

@media(max-width:820px) {
  .hero__image {
    height: 100%;
    position: relative;
    top: 0
  }
}

.hero__skipper {
  background-color: #fff;
  border: none;
  color: var(--colour-primary);
  flex-shrink: 0;
  font-size: 1rem;
  height: 60px;
  margin-right: 1rem;
  width: 60px
}

.hero__skipper .icon {
  transition: transform .4s
}

.hero__skipper:hover {
  background-color: var(--colour-primary);
  color: #fff
}

.hero__skipper:hover .icon {
  transform: translateY(4px)
}

.hero-status {
  padding-bottom: 7px;
  padding-top: 6px
}

.hero-status__content {
  margin-bottom: 15px
}

.hero-status__title {
  margin-right: 20px
}

.hero-navigation {
  align-items: flex-end;
  bottom: 0;
  display: flex;
  left: 0;
  padding-left: var(--content-space);
  position: absolute;
  width: 100%
}

@media(max-width:820px) {
  .hero-navigation {
    grid-column: 1/13
  }
}

@media(max-width:479px) {
  .hero-navigation {
    grid-column: 1/5;
    margin-bottom: -2rem;
    margin-top: 2rem;
    order: 10;
    padding: 0;
    position: relative
  }
}

.hero-navigation__list {
  width: 100%
}

.hero-navigation__accordion {
  height: 60px;
  margin: 0;
  position: relative
}

.hero-navigation__accordion .accordion__item {
  top: 0
}

.hero-navigation__accordion .accordion__icon {
  transition: transform .4s
}

.hero-navigation__accordion .accordion__title {
  background-color: #fff;
  color: var(--colour-font);
  display: inline-flex;
  font-size: var(--font-size-m);
  height: 60px;
  padding: .5rem 1rem;
  width: auto
}

.hero-navigation__accordion .accordion__title:hover:not(.hero-navigation__accordion .accordion__title.is-active) .accordion__icon {
  transform: rotate(90deg)
}

.hero-navigation__accordion .accordion__content {
  overflow: unset
}

.breadcrumb__link {
  color: inherit
}

.breadcrumb__divider {
  padding: 0 4px
}

.information {
  align-items: center;
  display: flex;
  justify-content: space-between
}

.information__date,
.information__name,
.information__position,
.information__time {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  font-weight: var(--font-weight-regular);
  line-height: 1.2;
  margin: 0;
  overflow: hidden
}

.information__date,
.information__name {
  font-weight: var(--font-weight-semibold)
}

.information__name--large {
  font-size: var(--font-size-h4);
  margin-bottom: 8px
}

.information__position--large {
  font-size: 20px
}

.information__person {
  align-items: center;
  display: flex
}

.information__avatar {
  background-color: #e1e1e1;
  border-radius: 50%;
  flex-shrink: 0;
  height: 44px;
  margin-right: 8px;
  overflow: hidden;
  width: 44px
}

.information__avatar--large {
  height: 95px;
  width: 95px
}

.information__sub {
  text-align: right
}

.menu {
  list-style: none;
  margin: 0;
  padding: 8px 0
}

.menu__item {
  border-bottom: 1px solid #d4d4d4;
  margin: 0;
  min-height: 40px;
  width: 100%
}

.menu__item:last-child {
  border-bottom: none
}

.menu__link {
  color: var(--colour-font);
  display: inline-block;
  height: 100%;
  padding: 16px 12px;
  width: 100%
}

.menu__link:hover {
  background-color: var(--colour-bg);
  color: inherit;
  text-decoration: none
}

.post-tag {
  background-color: var(--colour-font);
  font-size: var(--font-size-label);
  padding: 4px 6px 5px
}

.post-tag,
.quote {
  color: var(--colour-white)
}

.quote {
  background-color: var(--colour-primary);
  height: 100%;
  min-height: 335px;
  position: relative;
  width: 100%
}

@media(max-width:479px) {
  .quote {
    min-height: 0
  }
}

.quote.is-light {
  background-color: var(--colour-secondary);
  color: var(--colour-font)
}

@media(min-width:480px) {
  .quote__inner--vertical {
    margin-left: 40px
  }
}

.quote__container {
  height: 100%
}

.quote__wrapper {
  margin: 0 15px;
  max-width: 1094px;
  min-height: 335px;
  padding: 30px var(--content-space);
  width: 100%
}

@media(max-width:1093px) {
  .quote__wrapper {
    width: 100%
  }
}

@media(max-width:820px) {
  .quote__wrapper {
    margin-left: 0;
    padding-left: var(--content-space-m);
    padding-right: 0
  }
}

@media(max-width:480px) {
  .quote__wrapper {
    min-height: 0
  }
}

.quote__wrapper--vertical {
  max-width: 100%
}

.quote__item {
  height: 100%;
  max-width: 1094px
}

@media(max-width:1093px) {
  .quote__item {
    width: 100%
  }
}

@media(max-width:480px) {
  .quote__item {
    align-items: flex-start;
    display: block;
    padding-left: 20px
  }
}

.quote__item--vertical {
  flex-direction: column;
  justify-content: center;
  max-width: 100%
}

@media(max-width:480px) {
  .quote__figure {
    align-items: center;
    display: flex
  }
}

.quote__image {
  border-radius: 50%;
  display: inline-block;
  height: 150px;
  max-width: 150px;
  min-width: 150px;
  object-fit: cover
}

@media(max-width:480px) {
  .quote__image {
    height: 80px;
    max-width: 80px;
    min-width: 80px
  }
}

.quote__info {
  text-align: center
}

@media(max-width:480px) {
  .quote__info {
    margin-left: 20px;
    text-align: left
  }
}

.quote__name {
  font-weight: var(--font-weight-semibold);
  margin-bottom: 0;
  padding-top: 10.5px
}

.quote__indicators {
  bottom: 4px;
  left: 0;
  position: absolute;
  right: 0;
  text-align: center
}

.quote__indicator {
  background-color: transparent;
  border: none;
  display: inline-block;
  height: 16px;
  margin: 0 .166rem;
  opacity: .2;
  position: relative;
  width: 32px
}

.quote__indicator:before {
  background-color: #fff;
  content: "";
  height: 4px;
  left: 0;
  position: absolute;
  top: 8px;
  width: 100%
}

.quote__indicator.is-active {
  opacity: 1
}

.quote__arrow {
  background: linear-gradient(90deg, rgba(211, 18, 69, .8), rgba(211, 18, 69, .8) 30%, rgba(211, 18, 69, 0));
  background-color: transparent;
  border: none;
  height: 100%;
  left: 0;
  padding: 0;
  position: absolute;
  top: 0;
  width: 80px
}

@media(max-width:480px) {
  .quote__arrow {
    width: 40px
  }
}

.quote__arrow:before {
  content: "";
  display: block;
  font-family: var(--font-fontawesome);
  font-size: 32px;
  font-weight: 600;
  transition: transform .3s ease
}

@media(max-width:480px) {
  .quote__arrow:before {
    font-size: 24px
  }
}

.quote__arrow[rel=next] {
  background: linear-gradient(90deg, rgba(211, 18, 69, 0), rgba(211, 18, 69, .5));
  left: auto;
  right: 0
}

.quote__arrow[rel=next]:before {
  content: ""
}

.quote__arrow--light,
.quote__arrow--light[rel=next] {
  background: linear-gradient(90deg, hsla(38, 31%, 90%, .8), hsla(38, 31%, 90%, .8) 30%, rgba(211, 18, 69, 0))
}

.quote__arrow:hover:before {
  transform: translateY(3px) scale(1.1)
}

.quote__arrows {
  display: block
}

.quote__text {
  font-size: 22px;
  font-style: normal;
  font-weight: var(--font-weight-semibold);
  padding-left: 80px
}

@media(max-width:820px) {
  .quote__text {
    padding-left: 26px
  }
}

@media(max-width:480px) {
  .quote__text {
    font-size: 1rem;
    margin-top: 1rem;
    padding-left: 0
  }
}

.quote__text--vertical {
  padding-left: 0
}

.scroller {
  height: 50px;
  overflow: hidden;
  position: relative;
  width: 100%
}

.scroller__list {
  display: flex;
  left: 0;
  position: absolute;
  top: 0
}

.scroller__item {
  flex-shrink: 0;
  height: 50px;
  margin: 0 12px;
  min-width: 100px;
  text-align: center
}

.scroller__item img {
  height: 100%
}

.share__wrapper,
.social {
  align-items: center
}

.social {
  display: flex;
  margin-left: -10px
}

.social__list {
  margin-left: var(--content-space-m)
}

@media(max-width:479px) {
  .social__list {
    align-items: center;
    display: flex;
    margin-left: 25px
  }
}

.social__link {
  color: var(--colour-black)
}

.social__link:hover {
  transform: scale(1.125)
}

.social__item {
  box-sizing: content-box;
  color: var(--colour-font);
  display: inline-block;
  font-size: 25px;
  padding: 0 10px;
  text-align: center;
  transition: color .3s ease, transform .4s ease;
  width: 32px
}

.social__item--small {
  font-size: 24px;
  width: 24px
}

.social__item:hover {
  transform: scale(1.125)
}

@keyframes lds-dual-ring {
  0% {
    transform: rotate(0deg)
  }

  to {
    transform: rotate(1turn)
  }
}

.spinner {
  bottom: 0;
  display: inline-block;
  height: 80px;
  left: 0;
  margin: auto;
  position: fixed;
  right: 0;
  top: 0;
  width: 80px;
  z-index: 999
}

.spinner:after {
  animation: lds-dual-ring 1.2s linear infinite;
  border: 6px solid var(--colour-primary);
  border-color: var(--colour-primary) transparent;
  border-radius: 50%;
  content: " ";
  display: block;
  height: 64px;
  margin: 8px;
  width: 64px
}

.tab__container {
  display: flex;
  overflow: hidden;
  width: 100%
}

.tab__content {
  flex-shrink: 0;
  width: 100%
}

.email-subscription {
  background-size: cover;
  position: relative;
}
.email-subscription__overlay:before {
  opacity: .5
}

.email-subscription__overlay--dark:before,
.email-subscription__overlay:before {
  background: transparent linear-gradient(106deg, #000, transparent) 0 0 no-repeat padding-box;
  content: "";
  height: 100%;
  inset: 0;
  position: absolute;
  width: 100%
}

.email-subscription__overlay--dark:before {
  opacity: .7
}

.email-subscription__overlay--light:before {
  /* background: transparent linear-gradient(106deg, #000, transparent) 0 0 no-repeat padding-box; */
  content: "";
  height: 100%;
  inset: 0;
  opacity: .2;
  position: absolute;
  width: 100%
}

.email-subscription__inner {
  padding-bottom: 50px;
  padding-top: 50px;
  position: relative;
  z-index: 1;
}
.email-box {
background-image: url('../images/des8801_website-transformation-project_email-subscription.jpg');
}


.email-subscription__intro {
  align-self: center
}

@media(max-width:819px) {
  .email-subscription__intro {
    grid-column-end: 13 !important
  }
}

.email-subscription__title {
  color: var(--colour-white);
  font-size: var(--font-size-h1)
}

@media(max-width:819px) {
  .email-subscription__title {
    font-size: var(--font-size-h1-mobile)
  }
}

.email-subscription__subtitle {
  color: var(--colour-white)
}

@media(max-width:819px) {
  .email-subscription__form {
    grid-column-start: 1 !important
  }
}

.email-subscription-form {
  background-color: var(--colour-primary);
  color: var(--colour-white);
  display: flex;
  overflow: hidden;
  padding: 32px;
  position: relative
}

@media(max-width:479px) {
  .email-subscription-form {
    align-items: flex-start
  }
}

.email-subscription-form__inner {
  flex-shrink: 0;
  opacity: 0;
  visibility: hidden;
  width: 100%
}

.email-subscription-form__inner:first-of-type {
  display: flex;
  flex-direction: column;
  opacity: 1;
  visibility: visible
}

.email-subscription-form__title {
  color: var(--colour-white);
  margin: 0;
  padding-bottom: 15px
}

.email-subscription-form__label {
  color: var(--colour-white);
  display: block;
  font-weight: var(--font-weight-semibold);
  padding-bottom: 10px
}

.email-subscription-form__control {
  margin-bottom: 1rem
}

.email-subscription-form__consent {
  border-top: 1px solid hsla(0, 0%, 100%, .2);
  margin-bottom: 44px;
  margin-top: 24px;
  padding-top: 24px
}

.email-subscription-form .button-container {
  margin-bottom: 0;
  margin-top: auto
}

.featured-content {
  position: relative
}

@media(max-width:820px) {
  .featured-content {
    display: block !important
  }
}

.featured-content__overlay:before {
  opacity: .5
}

.featured-content__overlay--dark:before,
.featured-content__overlay:before {
  background: transparent linear-gradient(106deg, #000, transparent) 0 0 no-repeat padding-box;
  content: "";
  height: 100%;
  inset: 0;
  position: absolute;
  width: 100%;
  z-index: 1
}

.featured-content__overlay--dark:before {
  opacity: .7
}

.featured-content__overlay--light:before {
  background: transparent linear-gradient(106deg, #000, transparent) 0 0 no-repeat padding-box;
  content: "";
  height: 100%;
  inset: 0;
  opacity: .2;
  position: absolute;
  width: 100%;
  z-index: 1
}

.featured-content__wrapper {
  background-position: 50%;
  background-size: cover;
  min-height: 600px;
  padding: 0 5rem;
  position: relative
}

@media(max-width:1079px) {
  .featured-content__wrapper {
    min-height: 428px;
    padding: 0 2rem
  }
}

.featured-content__title {
  margin-top: 0
}

.featured-content__inner {
  height: 100%;
  margin: auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2);
  min-height: 600px;
  padding: 0 var(--content-space);
  width: 100%
}

@media(max-width:820px) {
  .featured-content__inner {
    padding: 0 var(--content-space-m)
  }
}

.featured-content__content {
  color: var(--colour-white);
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  max-width: 540px;
  min-height: inherit;
  position: relative;
  width: 100%;
  z-index: 1
}

.featured-content--medium .featured-content__inner,
.featured-content--medium .featured-content__wrapper {
  min-height: 487px
}

.featured-content--small .featured-content__inner,
.featured-content--small .featured-content__wrapper {
  min-height: 374px
}

.card {
  box-shadow: var(--shadow-card);
  max-width: 428px;
  position: relative;
  transition: transform .25s var(--ease-in-out-quad);
  width: 100%;
  z-index: 1
}

.card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(6px) scale(1.0125)
}

.card--person {
  width: 317px
}

.card--person,
.card--person:hover {
  box-shadow: none
}

.card--book,
.card--events,
.card--video {
  align-items: flex-end;
  color: #fff;
  display: flex
}

.card--book:before,
.card--events:before,
.card--video:before {
  background: linear-gradient(180deg, transparent 30%, rgba(0, 0, 0, .6) 60%);
  bottom: 0;
  content: "";
  height: 80%;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1
}

.card--book {
  align-items: flex-start
}

.card--book:before {
  display: none
}

.card--events {
  height: 428px
}

.card--video {
  height: 240px
}

.card--video-live {
  height: 367px;
  min-width: 650px
}

@media(max-width:820px) {
  .card--video-live {
    min-width: 100%
  }
}

.card--video-square {
  height: 428px;
  max-width: 428px
}

.card__subtitle {
  margin-bottom: 6px
}

.card__link {
  color: inherit;
  display: block;
  width: 100%
}

.card__link:hover {
  text-decoration: none
}

.card--events .card__link,
.card--video-default .card__link {
  align-items: flex-end;
  display: flex;
  height: 100%
}

.card__figure {
  background-color: var(--colour-bg);
  overflow: hidden;
  padding-top: 56.23%;
  position: relative
}

.card__figure--book {
  padding-top: 488px
}

.card__figure--book:before {
  background: linear-gradient(180deg, transparent 30%, rgba(0, 0, 0, .6) 60%);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1
}

.card--events .card__figure,
.card--video .card__figure {
  height: 100%;
  left: 0;
  padding: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -2
}

.card--video .card__figure iframe {
  height: 100%;
  width: 100%
}

.card--person .card__figure {
  padding-top: 100%
}

.card__image {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  transition: transform .35s var(--ease-in-out-quad);
  width: 100%
}

.card--events .card__image,
.card--video .card__image {
  position: relative
}

.card:hover .card__image {
  transform: scale(1.075)
}

.card__text {
  padding: 1rem
}

.card__text--book {
  color: #000;
  padding-left: 0;
  position: relative
}

.card__desc p {
  font-weight: var(--font-weight-regular)
}

.card__desc p:last-of-type {
  margin-bottom: 0
}

.card__info {
  margin-bottom: 1rem
}

.card__header-meta {
  margin-bottom: 6px
}

.card__title {
  margin-bottom: .366em;
  margin-top: 0
}

.card__title--video {
  font-size: 1.25rem
}

.card:hover .card__title {
  text-decoration: underline
}

.card__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 10px;
  row-gap: 5px
}

.card__tag {
  left: 1rem;
  position: absolute;
  top: 1rem
}

.card__meta-item {
  font-weight: var(--font-weight-regular);
  margin-right: 1rem
}

.card__play-button {
  color: #fff;
  display: flex;
  font-size: 50px;
  justify-content: center
}

.card__play-button--series {
  font-size: 45px
}

.card--video-default .card__play-button,
.card__play-button--series {
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%)
}

.card-list {
  display: flex;
  margin-left: calc(-50vw - -50%);
  padding-left: calc(50vw - 50% - var(--grid-gutter-space)/2);
  width: 100vw
}

@media(max-width:479px) {
  .card-list {
    margin-left: 0;
    padding-left: 0;
    width: 100%
  }
}

.card-list .card {
  flex-shrink: 0;
  margin: 0 calc(var(--grid-gutter-space)/2);
  width: calc(33.333% - var(--grid-gutter-space))
}

.card-list .card--book {
  box-shadow: none;
  min-height: 488px;
  width: calc(25% - var(--grid-gutter-space))
}

@media(max-width:820px) {
  .card-list .card {
    width: calc(50% - var(--content-space-s))
  }
}

@media(max-width:479px) {
  .card-list .card {
    margin: 0;
    width: 100%
  }

  .card-list .card:first-of-type {
    margin-left: 0
  }
}

.card-list--four-col .card {
  width: calc(25% - var(--grid-gutter-space))
}

@media(max-width:820px) {
  .card-list--four-col .card {
    width: calc(50% - var(--grid-gutter-space))
  }
}

@media(max-width:480px) {
  .card-list--four-col .card {
    margin: 0;
    max-width: none;
    width: 100%
  }
}

.card-list--listing {
  flex-wrap: wrap;
  margin-left: calc(var(--grid-gutter-space)/2*-1);
  padding-left: 0;
  width: calc(100% + var(--grid-gutter-space))
}

@media(max-width:479px) {
  .card-list--listing {
    margin-left: 0;
    width: 100%
  }
}

.card-list--listing .card {
  flex-shrink: 1;
  margin-bottom: 1rem
}

@media(max-width:479px) {
  .card-list--listing .card {
    margin-left: 0;
    margin-right: 0;
    width: 100%
  }
}

.card-list--listing .hero-card {
  flex-shrink: 1;
  margin: 0 calc(var(--grid-gutter-space)/2);
  margin-bottom: 1rem;
  width: calc(66.666% - var(--grid-gutter-space))
}

@media(max-width:820px) {
  .card-list--listing .hero-card {
    width: 100%
  }
}

@media(max-width:479px) {
  .card-list--listing .hero-card {
    margin-left: 0;
    margin-right: 0;
    width: 100%
  }
}

.card-list--vertical {
  flex-wrap: wrap;
  margin: 24px auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2 + var(--grid-gutter-space));
  padding-left: var(--content-space);
  padding-right: var(--content-space)
}

@media(max-width:480px) {
  .card-list--vertical {
    margin: 0;
    max-width: none;
    padding-left: var(--content-space-s);
    padding-right: var(--content-space-s);
    width: 100%
  }
}

.card-list--vertical .card {
  margin-bottom: calc(var(--grid-gutter-space)/2);
  margin-top: calc(var(--grid-gutter-space)/2)
}

@media(max-width:820px) {
  .card-list--vertical .expandable-list__item {
    width: 100%
  }
}

.card-list--full-width {
  max-width: 100%
}

.hero-card {
  min-width: 384px;
  position: relative;
  transition: all .25s var(--ease-in-out-quad)
}

@media(max-width:479px) {
  .hero-card {
    min-width: 0
  }
}

.hero-card:hover {
  transform: translateY(6px) scale(1.0125)
}

.hero-card__figure {
  background-color: #fff;
  height: 216px
}

@media(min-width:821px) {
  .hero-card__figure--two-columns {
    height: 474px;
    order: 2
  }
}

.hero-card__text {
  background-color: var(--colour-primary);
  color: var(--colour-white);
  padding: var(--content-space)
}

@media(min-width:821px) {
  .hero-card__text--two-columns {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: flex-end
  }

  .hero-card__link--two-columns {
    grid-column-gap: 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

.hero-card__title {
  margin-top: 0
}

.hero-card__meta {
  margin-top: var(--content-space-m)
}

.hero-card__meta-item {
  font-weight: var(--font-weight-regular);
  margin-right: 1rem
}

.hero-card__tag {
  left: 1rem;
  position: absolute;
  top: 1rem;
  z-index: 1
}

.hero-card__desc {
  font-weight: var(--font-weight-regular)
}

.mini-card {
  border-bottom: 1px solid hsla(22, 13%, 47%, .2);
  margin-bottom: 19px;
  max-width: 428px;
  padding-bottom: 29px
}

.mini-card__link {
  align-items: center;
  color: var(--colour-font);
  display: flex;
  justify-content: center;
  position: relative;
  width: 100%
}

.mini-card__figure {
  background-color: var(--colour-bg);
  flex-shrink: 0;
  height: 95px;
  margin-right: 1rem;
  width: 95px
}

.mini-card__title {
  font-size: 1.25rem;
  margin: 0
}

.mini-card__date {
  margin-top: 4px
}

.mini-card__date--title {
  margin-bottom: 0
}

.plain-card {
  max-width: 428px;
  position: relative
}

.plain-card--blog {
  border-bottom: 1px solid hsla(22, 13%, 47%, .2);
  margin-bottom: 16px;
  max-width: 206px;
  padding-bottom: 14px
}

@media(max-width:820px) {
  .plain-card--blog {
    max-width: 100%
  }
}

.plain-card__title {
  font-size: var(--font-size-m);
  margin-top: 0
}

.plain-card__meta {
  align-items: center;
  display: flex;
  justify-content: space-between
}

.search-result-card {
  border-bottom: 1px solid hsla(22, 13%, 47%, .2);
  margin-bottom: 22px;
  padding-bottom: 25px;
  position: relative
}

.search-result-card--global {
  max-width: 100%
}

.search-result-card--image {
  align-items: center;
  display: flex;
  gap: 30px
}

@media(max-width:820px) {
  .search-result-card--image {
    flex-direction: column
  }
}

.search-result-card--image img {
  max-width: 180px
}

@media(max-width:820px) {
  .search-result-card--image img {
    max-width: 100%
  }
}

.search-result-card__icon {
  color: var(--colour-primary);
  margin-right: 12px
}

.search-result-card__header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px
}

.search-result-card__title {
  margin: 0 15px 0 0
}

.search-result-card__desc :last-child {
  margin-bottom: 0
}

.search-result-card__meta {
  margin-bottom: 10px
}

.search-result-card__meta--item {
  display: inline-block;
  font-weight: 600;
  margin-right: 10px
}

.transcript__header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 1rem
}

.transcript__inner {
  height: 360px;
  overflow: auto
}

.transcript__list {
  list-style: none;
  margin: 0;
  padding: 0
}

.transcript__item {
  display: flex;
  gap: 12px;
  margin: 4px 0;
  width: 100%
}

.transcript__title {
  margin: 0
}

.transcript__time {
  min-width: 40px
}

.footer__inner {
  padding-bottom: 72px;
  padding-top: 72px
}

@media(max-width:819px) {
  .footer__inner {
    padding-bottom: 46px;
    padding-top: 46px
  }
}

.footer__info {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(12, 1fr);
  justify-content: space-between;
  margin-bottom: 56px
}

@media(max-width:479px) {
  .footer__info {
    grid-template-columns: repeat(4, 1fr)
  }
}

.footer__sub {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-left: 10px;
  margin-right: 10px
}

@media(max-width:819px) {
  .footer__sub {
    display: block
  }
}

.footer__intro {
  grid-column: 1/5
}

@media(max-width:819px) {
  .footer__intro {
    grid-column: 1/13
  }
}

.footer__sitemap {
  flex-shrink: 0;
  grid-column: 8/13
}

@media(max-width:819px) {
  .footer__sitemap {
    grid-column: 1/13
  }
}

.footer__logo {
  margin-bottom: var(--content-space);
  width: 280px
}

.footer__copyright {
  margin: 0
}

@media(max-width:819px) {
  .footer__copyright {
    margin-left: -10px;
    margin-top: 25px
  }
}

.sitemap {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(6, 1fr);
  grid-template-columns: 1fr 1fr 1fr;
  justify-content: space-between
}

@media(max-width:479px) {
  .sitemap {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media(max-width:819px) {

  .sitemap__list:first-of-type,
  .sitemap__list:last-of-type {
    grid-column: 1/7
  }

  .sitemap__list:nth-of-type(2) {
    grid-column: 7/13
  }

  .sitemap__list:last-of-type {
    margin-top: 20px
  }
}

.sitemap__label {
  font-size: 20px;
  font-weight: var(--font-weight-semibold);
  line-height: 1.3;
  margin-bottom: 20px
}

.sitemap__item {
  margin: 6px 0
}

.sitemap__link {
  color: var(--colour-font);
  font-weight: var(--font-weight-medium)
}

.global-search {
  position: relative
}

.global-search__form {
  background-color: #fff;
  bottom: 0;
  color: var(--colour-font);
  height: 60px;
  margin: auto;
  opacity: 0;
  position: absolute;
  right: -8px;
  top: 0;
  visibility: hidden;
  width: 0
}

.global-search__input {
  background: none;
  border: none;
  font-family: var(--font-secondary);
  font-size: var(--font-size-m);
  height: 100%;
  letter-spacing: .11px;
  outline: none;
  padding: 0 24px;
  width: 100%
}

.global-search__input::placeholder {
  color: var(--colour-font)
}

.global-search__trigger.is-active {
  color: var(--colour-font);
  text-shadow: none !important
}

.grid {
  grid-column-gap: var(--grid-gutter-space);
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-auto-flow: row;
  grid-template-columns: repeat(12, 1fr);
  justify-content: space-between
}

@media(max-width:479px) {
  .grid {
    grid-template-columns: repeat(4, 1fr)
  }
}

.grid.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr))
}

.grid.grid-cols-2 .card {
  max-width: 100%
}

.grid.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr))
}

.grid.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

.grid.grid-cols-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr))
}

.grid.grid-cols-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr))
}

.grid.grid-cols-7 {
  grid-template-columns: repeat(7, minmax(0, 1fr))
}

.grid.grid-cols-8 {
  grid-template-columns: repeat(8, minmax(0, 1fr))
}

.grid.grid-cols-9 {
  grid-template-columns: repeat(9, minmax(0, 1fr))
}

.grid.grid-cols-10 {
  grid-template-columns: repeat(10, minmax(0, 1fr))
}

.grid.grid-cols-11 {
  grid-template-columns: repeat(11, minmax(0, 1fr))
}

.grid.grid-cols-12 {
  grid-template-columns: repeat(12, minmax(0, 1fr))
}

@media(min-width:481px) {
  .grid.sm\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-8 {
    grid-template-columns: repeat(8, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-9 {
    grid-template-columns: repeat(9, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-10 {
    grid-template-columns: repeat(10, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-11 {
    grid-template-columns: repeat(11, minmax(0, 1fr))
  }

  .grid.sm\:grid-cols-12 {
    grid-template-columns: repeat(12, minmax(0, 1fr))
  }
}

@media(min-width:821px) {
  .grid.md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-8 {
    grid-template-columns: repeat(8, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-9 {
    grid-template-columns: repeat(9, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-10 {
    grid-template-columns: repeat(10, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-11 {
    grid-template-columns: repeat(11, minmax(0, 1fr))
  }

  .grid.md\:grid-cols-12 {
    grid-template-columns: repeat(12, minmax(0, 1fr))
  }
}

@media(min-width:1081px) {
  .grid.lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-7 {
    grid-template-columns: repeat(7, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-8 {
    grid-template-columns: repeat(8, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-9 {
    grid-template-columns: repeat(9, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-10 {
    grid-template-columns: repeat(10, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-11 {
    grid-template-columns: repeat(11, minmax(0, 1fr))
  }

  .grid.lg\:grid-cols-12 {
    grid-template-columns: repeat(12, minmax(0, 1fr))
  }
}

.grid__item.col-start-1 {
  grid-column-start: 1
}

.grid__item.col-start-2 {
  grid-column-start: 2
}

.grid__item.col-start-3 {
  grid-column-start: 3
}

.grid__item.col-start-4 {
  grid-column-start: 4
}

.grid__item.col-start-5 {
  grid-column-start: 5
}

.grid__item.col-start-6 {
  grid-column-start: 6
}

.grid__item.col-start-7 {
  grid-column-start: 7
}

.grid__item.col-start-8 {
  grid-column-start: 8
}

.grid__item.col-start-9 {
  grid-column-start: 9
}

.grid__item.col-start-10 {
  grid-column-start: 10
}

.grid__item.col-start-11 {
  grid-column-start: 11
}

.grid__item.col-start-12 {
  grid-column-start: 12
}

.grid__item.col-start-13 {
  grid-column-start: 13
}

.grid__item.col-end-1 {
  grid-column-end: 1
}

.grid__item.col-end-2 {
  grid-column-end: 2
}

.grid__item.col-end-3 {
  grid-column-end: 3
}

.grid__item.col-end-4 {
  grid-column-end: 4
}

.grid__item.col-end-5 {
  grid-column-end: 5
}

.grid__item.col-end-6 {
  grid-column-end: 6
}

.grid__item.col-end-7 {
  grid-column-end: 7
}

.grid__item.col-end-8 {
  grid-column-end: 8
}

.grid__item.col-end-9 {
  grid-column-end: 9
}

.grid__item.col-end-10 {
  grid-column-end: 10
}

.grid__item.col-end-11 {
  grid-column-end: 11
}

.grid__item.col-end-12 {
  grid-column-end: 12
}

.grid__item.col-end-13 {
  grid-column-end: 13
}

.grid__item.row-start-1 {
  grid-row-start: 1
}

.grid__item.row-start-2 {
  grid-row-start: 2
}

.grid__item.row-start-3 {
  grid-row-start: 3
}

.grid__item.row-start-4 {
  grid-row-start: 4
}

.grid__item.row-start-5 {
  grid-row-start: 5
}

.grid__item.row-start-6 {
  grid-row-start: 6
}

.grid__item.row-start-7 {
  grid-row-start: 7
}

.grid__item.row-start-8 {
  grid-row-start: 8
}

.grid__item.row-start-9 {
  grid-row-start: 9
}

.grid__item.row-start-10 {
  grid-row-start: 10
}

.grid__item.row-start-11 {
  grid-row-start: 11
}

.grid__item.row-start-12 {
  grid-row-start: 12
}

.grid__item.row-start-13 {
  grid-row-start: 13
}

.grid__item.row-end-1 {
  grid-row-end: 1
}

.grid__item.row-end-2 {
  grid-row-end: 2
}

.grid__item.row-end-3 {
  grid-row-end: 3
}

.grid__item.row-end-4 {
  grid-row-end: 4
}

.grid__item.row-end-5 {
  grid-row-end: 5
}

.grid__item.row-end-6 {
  grid-row-end: 6
}

.grid__item.row-end-7 {
  grid-row-end: 7
}

.grid__item.row-end-8 {
  grid-row-end: 8
}

.grid__item.row-end-9 {
  grid-row-end: 9
}

.grid__item.row-end-10 {
  grid-row-end: 10
}

.grid__item.row-end-11 {
  grid-row-end: 11
}

.grid__item.row-end-12 {
  grid-row-end: 12
}

.grid__item.row-end-13 {
  grid-row-end: 13
}

@media(min-width:481px) {
  .grid__item.sm\:col-start-1 {
    grid-column-start: 1
  }

  .grid__item.sm\:col-start-2 {
    grid-column-start: 2
  }

  .grid__item.sm\:col-start-3 {
    grid-column-start: 3
  }

  .grid__item.sm\:col-start-4 {
    grid-column-start: 4
  }

  .grid__item.sm\:col-start-5 {
    grid-column-start: 5
  }

  .grid__item.sm\:col-start-6 {
    grid-column-start: 6
  }

  .grid__item.sm\:col-start-7 {
    grid-column-start: 7
  }

  .grid__item.sm\:col-start-8 {
    grid-column-start: 8
  }

  .grid__item.sm\:col-start-9 {
    grid-column-start: 9
  }

  .grid__item.sm\:col-start-10 {
    grid-column-start: 10
  }

  .grid__item.sm\:col-start-11 {
    grid-column-start: 11
  }

  .grid__item.sm\:col-start-12 {
    grid-column-start: 12
  }

  .grid__item.sm\:col-start-13 {
    grid-column-start: 13
  }

  .grid__item.sm\:col-end-1 {
    grid-column-end: 1
  }

  .grid__item.sm\:col-end-2 {
    grid-column-end: 2
  }

  .grid__item.sm\:col-end-3 {
    grid-column-end: 3
  }

  .grid__item.sm\:col-end-4 {
    grid-column-end: 4
  }

  .grid__item.sm\:col-end-5 {
    grid-column-end: 5
  }

  .grid__item.sm\:col-end-6 {
    grid-column-end: 6
  }

  .grid__item.sm\:col-end-7 {
    grid-column-end: 7
  }

  .grid__item.sm\:col-end-8 {
    grid-column-end: 8
  }

  .grid__item.sm\:col-end-9 {
    grid-column-end: 9
  }

  .grid__item.sm\:col-end-10 {
    grid-column-end: 10
  }

  .grid__item.sm\:col-end-11 {
    grid-column-end: 11
  }

  .grid__item.sm\:col-end-12 {
    grid-column-end: 12
  }

  .grid__item.sm\:col-end-13 {
    grid-column-end: 13
  }

  .grid__item.sm\:row-start-1 {
    grid-row-start: 1
  }

  .grid__item.sm\:row-start-2 {
    grid-row-start: 2
  }

  .grid__item.sm\:row-start-3 {
    grid-row-start: 3
  }

  .grid__item.sm\:row-start-4 {
    grid-row-start: 4
  }

  .grid__item.sm\:row-start-5 {
    grid-row-start: 5
  }

  .grid__item.sm\:row-start-6 {
    grid-row-start: 6
  }

  .grid__item.sm\:row-start-7 {
    grid-row-start: 7
  }

  .grid__item.sm\:row-start-8 {
    grid-row-start: 8
  }

  .grid__item.sm\:row-start-9 {
    grid-row-start: 9
  }

  .grid__item.sm\:row-start-10 {
    grid-row-start: 10
  }

  .grid__item.sm\:row-start-11 {
    grid-row-start: 11
  }

  .grid__item.sm\:row-start-12 {
    grid-row-start: 12
  }

  .grid__item.sm\:row-start-13 {
    grid-row-start: 13
  }

  .grid__item.sm\:row-end-1 {
    grid-row-end: 1
  }

  .grid__item.sm\:row-end-2 {
    grid-row-end: 2
  }

  .grid__item.sm\:row-end-3 {
    grid-row-end: 3
  }

  .grid__item.sm\:row-end-4 {
    grid-row-end: 4
  }

  .grid__item.sm\:row-end-5 {
    grid-row-end: 5
  }

  .grid__item.sm\:row-end-6 {
    grid-row-end: 6
  }

  .grid__item.sm\:row-end-7 {
    grid-row-end: 7
  }

  .grid__item.sm\:row-end-8 {
    grid-row-end: 8
  }

  .grid__item.sm\:row-end-9 {
    grid-row-end: 9
  }

  .grid__item.sm\:row-end-10 {
    grid-row-end: 10
  }

  .grid__item.sm\:row-end-11 {
    grid-row-end: 11
  }

  .grid__item.sm\:row-end-12 {
    grid-row-end: 12
  }

  .grid__item.sm\:row-end-13 {
    grid-row-end: 13
  }
}

@media(min-width:821px) {
  .grid__item.md\:col-start-1 {
    grid-column-start: 1
  }

  .grid__item.md\:col-start-2 {
    grid-column-start: 2
  }

  .grid__item.md\:col-start-3 {
    grid-column-start: 3
  }

  .grid__item.md\:col-start-4 {
    grid-column-start: 4
  }

  .grid__item.md\:col-start-5 {
    grid-column-start: 5
  }

  .grid__item.md\:col-start-6 {
    grid-column-start: 6
  }

  .grid__item.md\:col-start-7 {
    grid-column-start: 7
  }

  .grid__item.md\:col-start-8 {
    grid-column-start: 8
  }

  .grid__item.md\:col-start-9 {
    grid-column-start: 9
  }

  .grid__item.md\:col-start-10 {
    grid-column-start: 10
  }

  .grid__item.md\:col-start-11 {
    grid-column-start: 11
  }

  .grid__item.md\:col-start-12 {
    grid-column-start: 12
  }

  .grid__item.md\:col-start-13 {
    grid-column-start: 13
  }

  .grid__item.md\:col-end-1 {
    grid-column-end: 1
  }

  .grid__item.md\:col-end-2 {
    grid-column-end: 2
  }

  .grid__item.md\:col-end-3 {
    grid-column-end: 3
  }

  .grid__item.md\:col-end-4 {
    grid-column-end: 4
  }

  .grid__item.md\:col-end-5 {
    grid-column-end: 5
  }

  .grid__item.md\:col-end-6 {
    grid-column-end: 6
  }

  .grid__item.md\:col-end-7 {
    grid-column-end: 7
  }

  .grid__item.md\:col-end-8 {
    grid-column-end: 8
  }

  .grid__item.md\:col-end-9 {
    grid-column-end: 9
  }

  .grid__item.md\:col-end-10 {
    grid-column-end: 10
  }

  .grid__item.md\:col-end-11 {
    grid-column-end: 11
  }

  .grid__item.md\:col-end-12 {
    grid-column-end: 12
  }

  .grid__item.md\:col-end-13 {
    grid-column-end: 13
  }

  .grid__item.md\:row-start-1 {
    grid-row-start: 1
  }

  .grid__item.md\:row-start-2 {
    grid-row-start: 2
  }

  .grid__item.md\:row-start-3 {
    grid-row-start: 3
  }

  .grid__item.md\:row-start-4 {
    grid-row-start: 4
  }

  .grid__item.md\:row-start-5 {
    grid-row-start: 5
  }

  .grid__item.md\:row-start-6 {
    grid-row-start: 6
  }

  .grid__item.md\:row-start-7 {
    grid-row-start: 7
  }

  .grid__item.md\:row-start-8 {
    grid-row-start: 8
  }

  .grid__item.md\:row-start-9 {
    grid-row-start: 9
  }

  .grid__item.md\:row-start-10 {
    grid-row-start: 10
  }

  .grid__item.md\:row-start-11 {
    grid-row-start: 11
  }

  .grid__item.md\:row-start-12 {
    grid-row-start: 12
  }

  .grid__item.md\:row-start-13 {
    grid-row-start: 13
  }

  .grid__item.md\:row-end-1 {
    grid-row-end: 1
  }

  .grid__item.md\:row-end-2 {
    grid-row-end: 2
  }

  .grid__item.md\:row-end-3 {
    grid-row-end: 3
  }

  .grid__item.md\:row-end-4 {
    grid-row-end: 4
  }

  .grid__item.md\:row-end-5 {
    grid-row-end: 5
  }

  .grid__item.md\:row-end-6 {
    grid-row-end: 6
  }

  .grid__item.md\:row-end-7 {
    grid-row-end: 7
  }

  .grid__item.md\:row-end-8 {
    grid-row-end: 8
  }

  .grid__item.md\:row-end-9 {
    grid-row-end: 9
  }

  .grid__item.md\:row-end-10 {
    grid-row-end: 10
  }

  .grid__item.md\:row-end-11 {
    grid-row-end: 11
  }

  .grid__item.md\:row-end-12 {
    grid-row-end: 12
  }

  .grid__item.md\:row-end-13 {
    grid-row-end: 13
  }
}

@media(min-width:1081px) {
  .grid__item.lg\:col-start-1 {
    grid-column-start: 1
  }

  .grid__item.lg\:col-start-2 {
    grid-column-start: 2
  }

  .grid__item.lg\:col-start-3 {
    grid-column-start: 3
  }

  .grid__item.lg\:col-start-4 {
    grid-column-start: 4
  }

  .grid__item.lg\:col-start-5 {
    grid-column-start: 5
  }

  .grid__item.lg\:col-start-6 {
    grid-column-start: 6
  }

  .grid__item.lg\:col-start-7 {
    grid-column-start: 7
  }

  .grid__item.lg\:col-start-8 {
    grid-column-start: 8
  }

  .grid__item.lg\:col-start-9 {
    grid-column-start: 9
  }

  .grid__item.lg\:col-start-10 {
    grid-column-start: 10
  }

  .grid__item.lg\:col-start-11 {
    grid-column-start: 11
  }

  .grid__item.lg\:col-start-12 {
    grid-column-start: 12
  }

  .grid__item.lg\:col-start-13 {
    grid-column-start: 13
  }

  .grid__item.lg\:col-end-1 {
    grid-column-end: 1
  }

  .grid__item.lg\:col-end-2 {
    grid-column-end: 2
  }

  .grid__item.lg\:col-end-3 {
    grid-column-end: 3
  }

  .grid__item.lg\:col-end-4 {
    grid-column-end: 4
  }

  .grid__item.lg\:col-end-5 {
    grid-column-end: 5
  }

  .grid__item.lg\:col-end-6 {
    grid-column-end: 6
  }

  .grid__item.lg\:col-end-7 {
    grid-column-end: 7
  }

  .grid__item.lg\:col-end-8 {
    grid-column-end: 8
  }

  .grid__item.lg\:col-end-9 {
    grid-column-end: 9
  }

  .grid__item.lg\:col-end-10 {
    grid-column-end: 10
  }

  .grid__item.lg\:col-end-11 {
    grid-column-end: 11
  }

  .grid__item.lg\:col-end-12 {
    grid-column-end: 12
  }

  .grid__item.lg\:col-end-13 {
    grid-column-end: 13
  }

  .grid__item.lg\:row-start-1 {
    grid-row-start: 1
  }

  .grid__item.lg\:row-start-2 {
    grid-row-start: 2
  }

  .grid__item.lg\:row-start-3 {
    grid-row-start: 3
  }

  .grid__item.lg\:row-start-4 {
    grid-row-start: 4
  }

  .grid__item.lg\:row-start-5 {
    grid-row-start: 5
  }

  .grid__item.lg\:row-start-6 {
    grid-row-start: 6
  }

  .grid__item.lg\:row-start-7 {
    grid-row-start: 7
  }

  .grid__item.lg\:row-start-8 {
    grid-row-start: 8
  }

  .grid__item.lg\:row-start-9 {
    grid-row-start: 9
  }

  .grid__item.lg\:row-start-10 {
    grid-row-start: 10
  }

  .grid__item.lg\:row-start-11 {
    grid-row-start: 11
  }

  .grid__item.lg\:row-start-12 {
    grid-row-start: 12
  }

  .grid__item.lg\:row-start-13 {
    grid-row-start: 13
  }

  .grid__item.lg\:row-end-1 {
    grid-row-end: 1
  }

  .grid__item.lg\:row-end-2 {
    grid-row-end: 2
  }

  .grid__item.lg\:row-end-3 {
    grid-row-end: 3
  }

  .grid__item.lg\:row-end-4 {
    grid-row-end: 4
  }

  .grid__item.lg\:row-end-5 {
    grid-row-end: 5
  }

  .grid__item.lg\:row-end-6 {
    grid-row-end: 6
  }

  .grid__item.lg\:row-end-7 {
    grid-row-end: 7
  }

  .grid__item.lg\:row-end-8 {
    grid-row-end: 8
  }

  .grid__item.lg\:row-end-9 {
    grid-row-end: 9
  }

  .grid__item.lg\:row-end-10 {
    grid-row-end: 10
  }

  .grid__item.lg\:row-end-11 {
    grid-row-end: 11
  }

  .grid__item.lg\:row-end-12 {
    grid-row-end: 12
  }

  .grid__item.lg\:row-end-13 {
    grid-row-end: 13
  }
}

.grid-gap-0 {
  grid-column-gap: 0
}

.header-login {
  flex-shrink: 0
}

.header-login__button {
  margin-right: 8px
}

.header-login__trigger {
  cursor: pointer
}

.header-login__trigger:hover {
  color: var(--colour-primary)
}

.header-login-view {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: var(--shadow-m);
  color: var(--colour-font);
  opacity: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 32px;
  visibility: hidden
}

.header-login-view__info {
  padding: var(--content-space)
}

.header-login-view__message {
  margin: 0
}

.header-login-view__name {
  font-family: var(--font-secondary)
}

.header-login-view__list {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  overflow: hidden
}

.header-login-view__link {
  color: var(--colour-font);
  display: inline-block;
  padding: calc(var(--content-space)/1.5) var(--content-space);
  text-shadow: none;
  width: 100%
}

.header-login-view__link:hover {
  background-color: #eee;
  color: var(--colour-font)
}

.header-login-view__item {
  white-space: nowrap
}

.header {
  height: var(--layout-header-height);
  left: 0;
  margin: auto;
  position: fixed;
  top: var(--fixed-top);
  width: 100%;
  z-index: 3
}

@media only screen and (max-width:1080px) {
  .header {
    height: 100px
  }

  .header:before {
    background-color: #fff;
    content: "";
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: opacity .6s;
    width: 100%;
    z-index: -1
  }

  .header.is-navigation-open:before {
    opacity: 1
  }
}

.header.is-light:not(.is-navigation-open):not(.is-fixed) {
  color: #fff
}

.header.is-fixed {
  background-color: #fff;
  box-shadow: var(--shadow-m);
  height: 100px
}

.header__inner {
  align-items: flex-end;
  display: flex;
  height: 100%
}

@media only screen and (max-width:1080px) {
  .header__inner {
    align-items: center
  }
}

.header.is-fixed .header__inner {
  align-items: flex-start
}

.header__logo {
  background-color: var(--colour-primary);
  color: var(--colour-font);
  display: inline-block;
  flex-shrink: 0;
  height: 100%;
  line-height: 1;
  width: 144px
}

@media only screen and (max-width:1080px) {
  .header__logo {
    height: 120px;
    position: relative;
    width: 120px;
    z-index: 100
  }
}

.header.is-fixed .header__logo {
  height: 120px;
  width: 120px;
  z-index: 1
}

.header__image {
  height: 100%
}

.header__actions {
  align-items: center;
  display: flex;
  height: 50%;
  justify-content: flex-end;
  margin-left: auto;
  margin-right: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 2
}

.header.is-fixed .header__actions {
  top: 4px
}

@media only screen and (max-width:1080px) {
  .header__actions {
    position: relative
  }
}

.header__action {
  background: none;
  border: none;
  font-size: 24px;
  margin: 0 4px;
  padding: 0 8px;
  text-shadow: var(--shadow-text-light)
}

.header.is-light:not(.is-fixed):not(.is-navigation-open) .header__action {
  text-shadow: var(--shadow-text-dark)
}

.header__signin {
  background: none;
  border: none;
  color: var(--colour-font);
  font-size: 1rem;
  padding: 0 12px
}

.header.is-light:not(.is-navigation-open):not(.is-fixed) .header__signin {
  color: #fff
}

.header.is-light:not(.is-fixed):not(.is-navigation-open) .header__signin {
  text-shadow: var(--shadow-text-dark)
}

.loader {
  bottom: 24px;
  display: none;
  height: 80px;
  position: fixed;
  right: 24px;
  width: 80px;
  z-index: 9999
}

.loader__content {
  align-items: flex-end;
  display: flex;
  height: 100%;
  justify-content: flex-end;
  width: 100%
}

.loader-ring {
  display: inline-block;
  height: 80px;
  position: relative;
  width: 80px
}

.loader-ring__item {
  animation: keyframe-loader-ring 1.2s cubic-bezier(.5, 0, .5, 1) infinite;
  border: 4px solid var(--colour-primary);
  border-color: var(--colour-primary) transparent transparent;
  border-radius: 50%;
  box-sizing: border-box;
  display: block;
  height: 64px;
  margin: 8px;
  position: absolute;
  width: 64px
}

.loader-ring__item:first-child {
  animation-delay: -.45s
}

.loader-ring__item:nth-child(2) {
  animation-delay: -.3s
}

.loader-ring__item:nth-child(3) {
  animation-delay: -.15s
}

@keyframes keyframe-loader-ring {
  0% {
    transform: rotate(0deg)
  }

  to {
    transform: rotate(1turn)
  }
}

.main,
.wrapper {
  position: relative
}

.main--no-hero {
  padding-top: calc(var(--layout-header-height) + 57px)
}

@media(max-width:820px) {
  .main--no-hero {
    padding-top: var(--layout-header-height)
  }
}

.not-found {
  align-items: center;
  background-size: cover;
  color: var(--colour-white);
  display: flex;
  height: calc(100vh - var(--layout-header-height));
  justify-content: center;
  min-height: 600px;
  padding-bottom: 8rem;
  padding-top: var(--layout-header-height)
}

.not-found__title {
  margin-bottom: 12px
}

.background {
  background-color: var(--colour-light-grey);
  left: 0;
  mask-position: bottom center;
  mask-repeat: no-repeat;
  mask-size: cover;
  min-height: 580px;
  overflow: visible;
  position: absolute;
  top: 0;
  width: 100%
}

.browsehappy {
  background: #ccc;
  color: #000;
  margin: .2em 0;
  padding: .2em 0
}

.svg-circle {
  transform: rotate(-90deg)
}

.svg-circle__indicator {
  stroke: var(--colour-primary);
  stroke-width: 3px
}

button:disabled .svg-circle__indicator {
  stroke: var(--colour-font-lightest)
}

button:disabled .svg-circle__track {
  stroke: transparent
}

.horizontal-scroll__list {
  -ms-overflow-style: none;
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none
}

.horizontal-scroll__list::-webkit-scrollbar {
  display: none
}

[data-animation] {
  opacity: 0
}

.book-image-author {
  margin-bottom: 40px;
  margin-top: -500px;
  width: 80%
}

@media(max-width:820px) {
  .book-image-author {
    display: none
  }
}

.post-content p:last-of-type {
  margin-bottom: 0
}

.simplebar-track {
  background-color: #eaeaea;
  border-radius: 4px
}

.simplebar-track.simplebar-vertical {
  width: 4px
}

.simplebar-scrollbar {
  background-color: #333132
}

.navigation-section {
  color: var(--colour-font);
  padding-top: 1rem
}

@media(max-width:479px) {
  .navigation-section {
    flex-direction: column
  }
}

.navigation-section__item {
  padding: 0 8px
}

@media(max-width:479px) {
  .navigation-section__item {
    width: 100%
  }
}

.navigation {
  align-items: flex-end;
  display: flex;
  height: 100%;
  justify-content: space-between;
  margin-left: 32px;
  position: relative;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .navigation {
    z-index: 99
  }
}

.header.is-fixed .navigation {
  padding-bottom: 3px
}

@media only screen and (max-width:1080px) {
  .header.is-fixed .navigation {
    align-items: center;
    padding-bottom: 0
  }
}

.navigation__inner {
  height: 50%;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .navigation__inner {
    background-color: #fff;
    color: var(--colour-font);
    height: calc(100dvh - 100px);
    left: 0;
    margin: 0;
    opacity: 0;
    overflow: auto;
    padding: 20px 0 0;
    position: fixed;
    top: 100px;
    visibility: hidden;
    width: 100%
  }
}

.navigation__menu {
  height: 100%
}

@media only screen and (max-width:1080px) {
  .navigation__menu {
    display: flex;
    flex-direction: column;
    height: auto;
    justify-content: center;
    padding-bottom: 80px;
    position: relative
  }
}

.navigation__list {
  display: flex;
  height: 100%;
  justify-content: space-around;
  margin: 0;
  padding: 0
}

@media only screen and (max-width:1080px) {
  .navigation__list {
    display: block;
    height: auto
  }
}

.navigation__item {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  margin: auto
}

.navigation__item:first-of-type {
  margin-left: 0
}

.navigation__item:last-of-type {
  margin-right: 0
}

@media only screen and (max-width:1080px) {
  .navigation__item {
    display: flex;
    height: auto;
    justify-content: space-between;
    padding: 12px 40px 12px 0
  }
}

@media(max-width:479px) {
  .navigation__item {
    padding: 6px 32px 6px 0
  }
}

.navigation__link {
  align-items: center;
  background: none;
  border: none;
  color: var(--colour-font);
  display: inline-flex;
  font-size: var(--font-size-m);
  height: 100%;
  justify-content: center;
  padding: 0;
  text-align: center;
  text-shadow: var(--shadow-text-light)
}

.navigation__link:hover {
  text-decoration: none
}

@media only screen and (max-width:1080px) {

  .navigation__link.is-active,
  .navigation__link:hover {
    font-weight: var(--font-weight-normal)
  }
}

.header:not(.is-light) .navigation__link.is-active,
.header:not(.is-light) .navigation__link:hover {
  color: var(--colour-font)
}

.navigation__item:first-child .navigation__link {
  padding-left: 0
}

.header.is-light:not(.is-fixed) .navigation__link {
  color: #fff;
  text-shadow: var(--shadow-text-dark)
}

@media only screen and (max-width:1080px) {
  .header.is-light:not(.is-fixed) .navigation__link {
    color: var(--colour-font);
    text-shadow: none
  }

  .navigation__link {
    font-family: var(--font-secondary);
    font-size: var(--font-size-h4);
    justify-content: space-between;
    letter-spacing: .24px;
    min-width: 0;
    text-align: left;
    width: 100%
  }

  .navigation__item:first-child .navigation__link,
  .navigation__link {
    padding: 4px 0 4px 36px
  }
}

.navigation__dropdown-button {
  background: none;
  border: none
}

.navigation__dropdown-button i {
  rotate: 45deg
}

.navigation-line {
  background-color: rgba(51, 49, 50, .15);
  bottom: 0;
  height: 3px;
  left: 0;
  position: absolute;
  width: 100%
}

@media only screen and (max-width:1080px) {
  .navigation-line {
    display: none
  }
}

.header.is-fixed .navigation-line {
  background-color: transparent
}

.header.is-light .navigation-line {
  background-color: hsla(0, 0%, 100%, .1)
}

.navigation-line__indicator {
  background-color: var(--colour-font);
  bottom: 0;
  height: 4px;
  left: 0;
  position: absolute;
  width: 0
}

.header.is-light .navigation-line__indicator {
  background-color: #fff
}

.header.is-light.is-fixed .navigation-line__indicator {
  background-color: var(--colour-font)
}

.overlay {
  background-color: #000;
  height: 100vh;
  left: 0;
  opacity: .6;
  position: fixed;
  top: var(--fixed-top);
  width: 100vw
}

.section {
  margin-bottom: var(--content-space-section);
  margin-top: var(--content-space-section)
}

@media(max-width:820px) {
  .section {
    margin-bottom: calc(var(--content-space-section)/2);
    margin-top: calc(var(--content-space-section)/2)
  }
}

.section--current-topics {
  align-items: center;
  background-position: 50%;
  background-size: cover;
  display: flex;
  min-height: 500px;
  padding-top: calc(var(--layout-header-height) + 20px);
  width: 100%
}

@media(max-width:820px) {
  .section--current-topics {
    min-height: 500px
  }
}

.section--interestedIn {
  padding-top: 0
}

.snackbar {
  left: 50%;
  margin: auto;
  opacity: 0;
  position: fixed;
  transform: translateX(-50%);
  visibility: hidden;
  z-index: 99
}

.snackbar__inner {
  align-items: center;
  background-color: var(--colour-primary);
  border-radius: 4px;
  box-shadow: var(--shadow-m);
  color: #fff;
  display: flex;
  min-width: 200px;
  padding: 8px 12px
}

.snackbar__content {
  margin-right: 24px;
  padding: 0 12px
}

.snackbar__button {
  background-color: hsla(0, 0%, 100%, .2);
  border: none;
  border-radius: 3px;
  color: #fff;
  height: 40px;
  width: 100px
}

.snackbar__button:hover {
  opacity: .85
}

.sticky-navigation {
  background-color: #fff;
  bottom: 0;
  left: 0;
  min-height: 8px;
  position: fixed;
  width: 100%;
  z-index: 10
}

.sticky-navigation__inner {
  position: relative;
  width: 100%
}

.sticky-navigation__main {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding: 1rem 0
}

.sticky-navigation__title {
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: var(--font-size-l);
  font-weight: var(--font-weight-medium);
  margin: 0;
  text-align: left
}

.sticky-navigation__title:after {
  align-items: center;
  content: "";
  display: inline-block;
  font-family: var(--font-fontawesome);
  font-weight: 900;
  height: 24px;
  justify-content: center;
  transition: transform .3s;
  vertical-align: -2px;
  width: 24px
}

.sticky-navigation__title.is-active:after {
  transform: rotateX(180deg)
}

.sticky-navigation-indicator {
  background-color: var(--colour-border-light);
  height: 8px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%
}

.sticky-navigation-indicator__value {
  background-color: var(--colour-primary);
  display: block;
  height: 100%;
  width: 0
}

.sticky-navigation-content {
  border-bottom: 1px solid var(--colour-border-light);
  font-weight: var(--font-weight-semibold);
  height: 0;
  opacity: 0;
  overflow: hidden;
  width: 100%
}

.sticky-navigation-content__inner {
  align-items: center;
  display: flex;
  height: 100%;
  overflow-x: auto;
  width: 100%
}

.sticky-navigation-content__label {
  flex-shrink: 0;
  font-size: var(--font-size-l);
  margin: 0 42px 0 0
}

.sticky-navigation-content__list {
  white-space: nowrap
}

.sticky-navigation-content__link {
  background: none;
  border: none;
  color: var(--colour-font);
  font-size: 1rem;
  margin-right: 24px;
  padding: 0
}

.basic {
  padding-bottom: var(--content-space-section)
}

.basic__scientific-into-title {
  margin-top: 25px
}

.blog {
  padding-top: 250px;
  position: relative;
  z-index: 1
}

@media(max-width:1079px) {
  .blog {
    padding-top: 0
  }
}

@media(max-width:820px) {
  .blog--person .blog-series {
    margin-bottom: 1.5rem
  }
}

.blog--person,
.blog--publication {
  padding-top: var(--layout-header-height)
}

@media(max-width:1079px) {

  .blog--person,
  .blog--publication {
    padding-top: 0
  }
}

.blog--person:before,
.blog--publication:before {
  display: none
}

.blog:before {
  background-color: var(--colour-tertiary);
  content: "";
  height: 515px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1
}

@media(max-width:1079px) {
  .blog:before {
    content: none
  }
}

.blog__image {
  padding: 30px 0
}

.blog__image img {
  object-fit: cover;
  width: 100%
}

.blog__title--person {
  margin-bottom: 8px
}

.blog__intro-title {
  margin-top: 0
}

.blog__article {
  grid-column-gap: var(--grid-gutter-space);
  background-color: #fff;
  display: grid;
  grid-auto-columns: minmax(0, 1fr);
  grid-auto-flow: column;
  grid-template-columns: repeat(12, 1fr);
  justify-content: space-between;
  margin: auto;
  max-width: var(--content-width-inner);
  padding: 80px 0
}

@media(max-width:479px) {
  .blog__article {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media(max-width:1079px) {
  .blog__article {
    background-color: transparent;
    margin-top: -80px;
    padding-top: 0
  }
}

@media(max-width:480px) {
  .blog__article {
    display: block
  }
}

.blog__article--wide {
  margin: auto;
  max-width: calc(var(--content-width-inner) + var(--content-space)*2);
  padding: 80px var(--content-space)
}

@media(max-width:820px) {
  .blog__article--wide {
    max-width: calc(var(--content-width-inner) + var(--content-space-m)*2);
    padding: 80px var(--content-space-m)
  }
}

.blog__article--person {
  padding-top: 0
}

.blog__section {
  grid-column: 2/12;
  margin-bottom: 24px
}

@media(max-width:1079px) {
  .blog__section {
    grid-column: 1/13
  }
}

@media(max-width:820px) {
  .blog__section {
    display: block
  }
}

@media(max-width:479px) {
  .blog__section {
    grid-column: 1/5
  }
}

.blog__section--wide {
  grid-column: 1/13
}

@media(max-width:479px) {
  .blog__section--wide {
    grid-column: 1/5
  }
}

@media(max-width:1079px) {
  .blog__content {
    grid-column: 1/13
  }
}

@media(max-width:820px) {
  .blog__content {
    padding: 0 var(--content-space-m)
  }
}

@media(max-width:479px) {
  .blog__content {
    grid-column: 1/5;
    padding: 0 var(--content-space-m)
  }
}

.blog__content--wide {
  padding: 0
}

@media(max-width:1079px) {
  .blog__content--alt {
    grid-column: 2/12
  }
}

@media(max-width:479px) {
  .blog__content--alt {
    grid-column: 1/5
  }
}

@media(min-width:1081px) {
  .blog__content .blog-header--single {
    margin-bottom: 0
  }
}

@media(max-width:820px) {
  .blog__content .blog-header--single {
    margin-left: calc(var(--content-space-m)*-1);
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog__related {
  grid-column: 1/13
}

@media(max-width:1315px) {
  .blog__related {
    padding: 0 var(--content-space)
  }
}

@media(max-width:820px) {
  .blog__related {
    padding: 0 var(--content-space-m)
  }
}

@media(max-width:479px) {
  .blog__related {
    grid-column: 1/5
  }
}

@media(max-width:1315px) {
  .blog__related--wide {
    padding: 0
  }
}

.blog__video-figure {
  overflow: hidden;
  padding-top: 52%;
  position: relative
}

@media(max-width:820px) {
  .blog__video-figure {
    margin-left: calc(var(--content-space-m)*-1);
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog__video-figure iframe {
  height: 100%;
  inset: 0;
  position: absolute;
  width: 100%
}

.blog__image-main {
  background-color: var(--colour-bg);
  height: 492px;
  object-fit: cover;
  width: 100%
}

@media(max-width:820px) {
  .blog__image-main {
    height: 321px;
    margin-left: calc(var(--content-space-m)*-1);
    max-width: unset;
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog__event-image-main {
  background-color: var(--colour-bg);
  height: 570px;
  object-fit: cover;
  width: 100%
}

@media(max-width:820px) {
  .blog__event-image-main {
    height: 223px;
    margin-left: calc(var(--content-space-m)*-1);
    max-width: unset;
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog__entry-content {
  margin-top: 24px
}

.blog__related-list {
  margin-top: calc(var(--content-space-section)/3)
}

.blog__related-list .card-list {
  padding-bottom: 1rem
}

.blog__related-list h3 {
  margin-top: 6px
}

@media(max-width:479px) {
  .blog__related-list .horizontal-scroll {
    margin-left: calc(var(--content-space-m)*-1);
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog__related-list:first-of-type {
  margin-top: 0
}

@media(max-width:820px) {
  .blog__featured-card {
    margin-bottom: 30px
  }
}

@media(min-width:821px) {
  .blog__featured-inner {
    padding-left: 0;
    padding-right: 0
  }
}

@media(max-width:480px) {
  .blog__quote-container {
    margin-left: calc(var(--content-space-m)*-1);
    width: calc(100% + var(--content-space-m)*2)
  }
}

.blog-aside {
  margin-top: 1rem
}

@media(max-width:820px) {
  .blog-aside {
    margin-top: 0
  }
}

.blog-aside--book {
  margin-top: 85px
}

@media(max-width:820px) {
  .blog-aside--book {
    margin-top: 0
  }
}

.blog-aside--book .information:not(:last-of-type) {
  margin-bottom: 30px
}

@media(max-width:820px) {
  .blog-aside--book .information:first-of-type {
    margin-top: 30px
  }
}

.blog-aside--person {
  margin-top: 0
}

@media(max-width:820px) {
  .blog-aside--person {
    display: flex
  }
}

@media(max-width:479px) {
  .blog-aside--person {
    display: block
  }
}

.blog-aside__title {
  margin-bottom: 22px;
  margin-top: 16px
}

@media(max-width:820px) {
  .blog-aside__title {
    margin-bottom: 12px
  }
}

.blog-aside__content {
  margin-bottom: 48px
}

@media(max-width:820px) {
  .blog-aside__content {
    margin-bottom: 24px
  }

  .blog-aside__content:first-of-type .blog-aside__title {
    margin-top: 8px
  }

  .blog-aside__content:last-of-type {
    margin-bottom: 0
  }
}

.blog-aside__information {
  cursor: pointer;
  margin-bottom: 24px;
  position: relative
}

.blog-aside__information:last-of-type {
  margin-bottom: 0
}

.blog-aside__information:hover {
  text-decoration: underline
}

.blog-aside--grant {
  margin-top: 0
}

@media(max-width:820px) {
  .blog-aside--grant {
    grid-row: 1
  }
}

.blog-component {
  margin-bottom: 20px;
  margin-top: 24px
}

@media(max-width:820px) {
  .blog-component {
    margin-bottom: 8px;
    margin-top: 26px
  }
}

.blog-component__title {
  margin-bottom: 44px;
  margin-top: 0
}

@media(max-width:820px) {
  .blog-component__title {
    margin-bottom: 26px
  }
}

.blog-component__title--small {
  margin-bottom: 0
}

.blog-series {
  padding-bottom: 24px;
  position: relative
}

@media(max-width:1079px) {
  .blog-series {
    height: auto;
    max-height: unset;
    padding: 0
  }
}

@media(max-width:820px) {
  .blog-series {
    margin: var(--content-space) 0 0
  }
}

.blog-series--large {
  max-height: 590px
}

@media(max-width:1079px) {
  .blog-series--large {
    height: auto;
    margin: var(--content-space) 0 0;
    max-height: unset
  }
}

.blog-series__inner {
  -ms-overflow-style: none;
  height: 100%;
  overflow: auto;
  scrollbar-width: none
}

.blog-series__inner::-webkit-scrollbar {
  display: none
}

@media(max-width:1079px) {
  .blog-series__inner {
    overflow: inherit
  }
}

@media(max-width:899px) {
  .blog-series__inner--title {
    font-size: 16px
  }
}

.blog-series__scroller {
  background-color: #fff;
  bottom: 0;
  color: var(--colour-primary);
  height: 24px;
  left: 0;
  position: absolute;
  text-align: center;
  width: 100%;
  z-index: 2
}

@media(max-width:1079px) {
  .blog-series__list {
    display: flex;
    overflow: auto
  }
}

@media(max-width:479px) {
  .blog-series__list {
    width: calc(100% + var(--content-space-m))
  }
}

.blog-series__link {
  color: var(--colour-font);
  display: block
}

@media(max-width:1079px) {
  .blog-series__link {
    flex-shrink: 0;
    margin: 0 calc(var(--grid-gutter-space)/2);
    width: calc(50% - var(--grid-gutter-space))
  }

  .blog-series__link:first-of-type {
    margin-left: 0
  }
}

@media(max-width:479px) {
  .blog-series__link {
    width: calc(100% - var(--content-space-m))
  }
}

.blog-series__figure {
  margin: 0 0 6px;
  position: relative
}

.blog-series__figure--container {
  position: relative
}

.blog-series__image {
  object-fit: cover;
  width: 100%
}

@media(max-width:899px) {
  .blog-series__image {
    aspect-ratio: 16/9;
    height: unset
  }
}

@media(max-width:1079px) {
  .blog-series__image {
    height: auto;
    width: 100%
  }
}

.blog-header {
  margin-bottom: var(--content-space-section)
}

@media(max-width:1079px) {
  .blog-header {
    background-color: var(--colour-tertiary);
    color: #fff;
    padding-bottom: 40px;
    padding-top: 240px
  }
}

@media(max-width:479px) {
  .blog-header {
    margin-bottom: 0
  }
}

@media(max-width:820px) {
  .blog-header--video {
    margin-bottom: 0
  }
}

.blog-header--person,
.blog-header--publication {
  grid-column: 1/13
}

@media(max-width:1079px) {

  .blog-header--person,
  .blog-header--publication {
    background-color: transparent;
    color: var(--colour-font);
    margin-top: 0;
    padding-bottom: 0;
    padding-top: 100px
  }
}

@media(max-width:480px) {

  .blog-header--person,
  .blog-header--publication {
    grid-column: 1/5
  }
}

.blog-header--person {
  margin-bottom: 0
}

@media(max-width:820px) {
  .blog-header--person {
    margin-bottom: 1rem;
    padding-top: 0
  }
}

.blog-header--publication {
  margin-bottom: var(--content-space-section)
}

.blog-header--publication .blog__title {
  margin-bottom: 1rem
}

@media(max-width:1079px) {
  .blog-header--single {
    grid-column-gap: var(--grid-gutter-space);
    display: grid;
    grid-auto-columns: minmax(0, 1fr);
    grid-auto-flow: column;
    grid-column: 1/13;
    grid-template-columns: repeat(12, 1fr);
    justify-content: space-between
  }
}

@media(max-width:1079px)and (max-width:479px) {
  .blog-header--single {
    grid-template-columns: repeat(4, 1fr)
  }
}

@media(max-width:820px) {
  .blog-header--single {
    display: block
  }
}

@media(max-width:1079px) {
  .blog-header__inner {
    grid-column: 2/12
  }
}

@media(max-width:479px) {
  .blog-header__inner {
    grid-column: 1/5
  }
}

@media(max-width:820px) {
  .blog-header--single .blog-header__inner {
    padding: 0 var(--content-space-m)
  }
}

.blog-header__info {
  align-items: center;
  display: flex;
  justify-content: space-between
}

@media(max-width:652px) {
  .blog-header__info {
    align-items: flex-start;
    flex-direction: column;
    row-gap: 15px
  }
}

.blog-header__info .addeventatc {
  align-items: center;
  border: none;
  border-radius: 0;
  box-shadow: none !important;
  color: var(--colour-font);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--font-primary);
  font-weight: 600;
  justify-content: center;
  line-height: 1.5;
  padding: 15px 24px;
  position: relative;
  transition: opacity .1s ease, transform .4s ease
}

.blog-header__info .addeventatc,
.blog-header__info .addeventatc:hover {
  background-color: var(--colour-secondary);
  font-size: 1rem
}

.blog-header__info .addeventatc_icon {
  display: none
}

.blog-header__metas {
  margin-bottom: -4px;
  margin-left: -.5rem;
  margin-top: -4px
}

.blog-header__meta {
  display: inline-block;
  margin: 4px .5rem
}

.blog-header__actions {
  flex-shrink: 0;
  margin-left: 12px
}

@media(max-width:652px) {
  .blog-header__actions {
    margin-left: 0
  }
}

.blog-tags__tag {
  display: inline-block;
  margin: 4px 2px;
  transition: opacity .1s ease, transform .4s ease
}

.blog-tags__tag:hover {
  opacity: .9;
  transform: translateY(-2px) scale(.98)
}

.blog-tags__link:hover {
  text-decoration: none
}

.blog-person__company {
  color: #000;
  font-weight: var(--font-weight-semibold);
  margin-bottom: 0;
  opacity: .5
}

@media(max-width:820px) {
  .blog-person__info {
    margin-left: var(--grid-gutter-space)
  }
}

@media(max-width:479px) {
  .blog-person__info {
    margin-left: 0
  }
}

.blog-person__figure {
  margin: 0 0 12px;
  position: relative
}

@media(max-width:479px) {
  .blog-person__image {
    width: 100%
  }
}

.blog-person__details {
  margin-top: 23px
}

.blog-person__detail {
  gap: 16px;
  margin-bottom: 23px
}

.blog-person__detail--link {
  color: var(--colour-font)
}

.blog-person__detail--icon {
  font-size: var(--font-size-l);
  text-align: center;
  width: 32px
}

@media(max-width:820px) {
  .blog-person__detail {
    margin-bottom: 1rem
  }
}

.blog-listing {
  margin-top: calc(var(--content-space-section)/3)
}

.blog-listing:first-of-type {
  margin-top: 0
}

.blog-listing .card-list {
  padding-bottom: 1rem
}

.blog-listing h3 {
  margin-top: 6px
}

@media(max-width:479px) {
  .blog-listing .horizontal-scroll {
    margin-left: calc(var(--content-space)*-1);
    width: calc(100% + var(--content-space)*2)
  }
}

.blog-listing__header {
  align-items: center;
  display: flex;
  justify-content: space-between
}

@media(max-width:479px) {
  .blog-listing__header {
    margin-bottom: 1rem
  }
}

.blog-listing__header--simple {
  margin-bottom: 1rem
}

.blog-listing__button {
  flex-shrink: 0;
  margin-left: 8px
}

.grant__information {
  margin-bottom: 24px
}

.grant__information:first-of-type {
  margin-top: 24px
}

.grant__content {
  padding-top: 48px
}

.home-list {
  margin-bottom: 64px
}

@media(max-width:820px) {
  .home-list {
    margin-bottom: 40px
  }
}

.home-list__header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 46px
}

@media(max-width:820px) {
  .home-list__header {
    margin-bottom: 20px
  }
}

.home-list__title {
  margin: 0
}

.home .section--grid {
  padding-bottom: 0
}

.home .section--featuredContent {
  padding-top: 0
}

.login-page {
  align-items: center;
  background-size: cover;
  color: var(--colour-white);
  display: flex;
  height: 100vh;
  justify-content: center;
  min-height: 600px;
  padding-bottom: 8rem;
  padding-top: var(--layout-header-height)
}

@media(max-width:820px) {
  .login-page__page-title {
    font-size: var(--font-size-h2-mobile)
  }

  .login-page__form {
    margin-bottom: 40px;
    margin-top: 40px
  }
}

.login-page__form-control {
  margin-bottom: 1rem
}

.login-page__title {
  margin-top: 0
}

@media(max-width:820px) {
  .login-page__title {
    font-size: var(--font-size-h1-mobile)
  }
}

.login-page__link {
  color: #fff;
  font-weight: var(--font-wight-semibold)
}

.search-results {
  margin-top: 57px
}

@media(max-width:820px) {
  .search-results {
    margin-top: 0
  }
}

.search-results__title {
  margin-bottom: 58px
}

@media(max-width:479px) {
  .search-results__title {
    margin-bottom: 20px
  }
}

.search-results__results {
  margin-top: 58px
}

.search-results__content {
  margin-top: 38px
}

@media(max-width:479px) {
  .search-results__content {
    margin-top: 0
  }
}

.search-results__aside--title {
  margin-bottom: 17px
}